# L64704 Satellite Decoder

# **Technical Manual**

May 1997



Order Number I14010.A

Document DB14-000026-01, Second Edition (May 1997) This document describes Revision A of LSI Logic Corporation's L64704 Satellite Decoder and will remain the official reference source for all revisions of this product until rescinded by an update.

To receive product literature, call us at 1.800.574.4286 (U.S. and Canada); +32.11.300.531 (Europe); 408.433.7700 (outside U.S., Canada, and Europe) and ask for Department JDS; or visit us at http://www.lsilogic.com.

LSI Logic Corporation reserves the right to make changes to any products herein at any time without notice. LSI Logic does not assume any responsibility or liability arising out of the application or use of any product described herein, except as expressly agreed to in writing by LSI Logic; nor does the purchase or use of a product from LSI Logic convey a license under any patent rights, copyrights, trademark rights, or any other of the intellectual property rights of LSI Logic or third parties.

Copyright © 1995, 1996, 1997 by LSI Logic Corporation. All rights reserved.

#### TRADEMARK ACKNOWLEDGMENT

LSI Logic logo design is a registered trademark of LSI Logic Corporation. All other brand and product names may be trademarks of their respective companies.

## Contents

| Chapter 1 | Introduction              |                                                    |      |  |  |
|-----------|---------------------------|----------------------------------------------------|------|--|--|
|           | 1.1                       | General Description                                | 1-1  |  |  |
|           | 1.2                       | Typical Application                                | 1-3  |  |  |
|           | 1.3                       | Features Summary                                   | 1-5  |  |  |
| Chapter 2 | L64704 Signal Definitions |                                                    |      |  |  |
|           | 2.1                       | Channel Interface                                  | 2-3  |  |  |
|           | 2.2                       | Channel Clock Recovery                             |      |  |  |
|           | 2.3                       | Channel Data Output Interface                      | 2-4  |  |  |
|           | 2.4                       | Phase-Locked Loop Interface                        | 2-5  |  |  |
|           | 2.5                       | Carrier Synchronizer Loop Controls                 | 2-6  |  |  |
|           | 2.6                       | Microcontroller Interface                          | 2-7  |  |  |
|           | 2.7                       | Control Signals                                    | 2-9  |  |  |
| Chapter 3 | L64704 Registers          |                                                    |      |  |  |
|           | 3.1                       | L64704 Register Overview                           | 3-2  |  |  |
|           |                           | 3.1.1 Parallel Host Mode Register Operations       | 3-7  |  |  |
|           |                           | 3.1.2 Programming Using the Serial Interface       | 3-9  |  |  |
|           | 3.2                       | Reset and How It Affects Registers                 | 3-9  |  |  |
|           | 3.3                       | Group 0, 1 Address Pointer Register                | 3-10 |  |  |
|           | 3.4                       | Group 2 Registers                                  | 3-11 |  |  |
|           |                           | 3.4.1 System Mode Register (SMR)                   | 3-11 |  |  |
|           |                           | 3.4.2 System Status Register (STS)                 | 3-16 |  |  |
|           | 3.5                       | Group 3 Registers                                  | 3-20 |  |  |
|           |                           | 3.5.1 Group 3, APR 0, 1 RS Corrected Error Count   | 3-21 |  |  |
|           |                           | 3.5.2 Group 3, APR 2, 3 RS Uncorrected Error Count | 3-21 |  |  |
|           |                           | 3.5.3 Group 3, APR 4, 5 Viterbi Bit Error Count    | 3-22 |  |  |
|           |                           | 3.5.4 Group 3, APR 6 Control Input and SNR         | 3-22 |  |  |
|           |                           | 3.5.5 Group 3, APR 6, 7 Measured VCO Frequency     | 3-23 |  |  |
|           |                           |                                                    |      |  |  |

|     | 3.5.6   | Group 3, APR 8 AGC Loop Voltage Meter                                       | 3-23   |
|-----|---------|-----------------------------------------------------------------------------|--------|
|     | 3.5.7   | Group 3, APR 9 Carrier and FEC Synchronization S 3-23                       | Status |
|     | 3.5.8   | Group 3, APR 10 RI Readback                                                 | 3-25   |
|     | 3.5.9   | Group 3, APR 11 RQ Readback                                                 | 3-26   |
| 3.6 | Group 4 | Registers                                                                   | 3-26   |
|     | 3.6.1   | Group 4, APR 0 PLL Parameter N                                              | 3-28   |
|     | 3.6.2   | Group 4, APR 1 PLL Parameter S                                              | 3-28   |
|     | 3.6.3   | Group 4, APR 2 PLL Parameter T, Demodulator and Symbol Select               | 3-29   |
|     | 3.6.4   | Group 4, APR 3 PLL Parameter M, Transport and Viterbi Code Rate Select      | 3-30   |
|     | 3.6.5   | Group 4, APR 4 Viterbi Max Data Bit Count 1                                 | 3-31   |
|     | 3.6.6   | Group 4, APR 5, 6, 7 Viterbi Max Data Bit Count 2                           | 3-31   |
|     | 3.6.7   | Group 4, APR 8 Viterbi Maximum Bit Error Count                              | 3-32   |
|     | 3.6.8   | Group 4, APR 9 Synchronization Word                                         | 3-32   |
|     | 3.6.9   | Group 4, APR 10 BER Monitor and Mismatching<br>Bits in Sync 2 Tracking Mode | 3-33   |
|     | 3.6.10  | Group 4, APR 11 Synchronization States and BCLKOUT Format                   | 3-34   |
|     | 3.6.11  | Group 4, APR 12 Output Control                                              | 3-36   |
|     | 3.6.12  | Group 4, APR 13 PLL Reset                                                   | 3-37   |
|     | 3.6.13  | Group 4, APR 14 Clock Loop Control 1                                        | 3-37   |
|     | 3.6.14  | Group 4, APR 15 Clock Loop Control 2                                        | 3-39   |
|     | 3.6.15  | Group 4, APR 16, 17 Nominal Frequency of                                    |        |
|     |         | Clock Input                                                                 | 3-40   |
|     | 3.6.16  | Group 4, APR 18 Clock Ratio                                                 | 3-40   |
|     | 3.6.17  | Group 4, APR 19 Power Reference Level                                       | 3-41   |
|     | 3.6.18  | Group 4, APR 20 Power Estimation Bandwidth and I/Q DC Offset                | 3-41   |
|     | 3.6.19  | Group 4, APR 21 Scale Factor for DEMI and DEMQ Outputs                      | 3-42   |
|     | 3.6.20  | Group 4, APR 22 SNR Estimator Threshold                                     | 3-42   |
|     | 3.6.21  | Group 4, APR 23 Carrier Loop DC Offset                                      |        |
|     |         | Compensation Value                                                          | 3-42   |
|     | 3.6.22  | Group 4, APR 24 Carrier Frequency Reference<br>Period                       | 3-42   |
|     | 3.6.23  | Group 4, APR 25, 26 Carrier Loop Filter Gain                                |        |
|     |         | (P and D Terms)                                                             | 3-43   |

|           |      | 3.6.24     | Group 4, APR 27 Carrier Lock Detector Threshold               | 3-43      |
|-----------|------|------------|---------------------------------------------------------------|-----------|
|           |      | 3.6.25     | Group 4, APR 28 Carrier Synchronizer Sweep                    |           |
|           |      |            | Rate                                                          | 3-44      |
|           |      | 3.6.26     | Group 4, APR 29, 30 Carrier Synchronizer Sweep<br>Upper Limit | )<br>3-44 |
|           |      | 3.6.27     | Group 4, APR 31, 32 Carrier Synchronizer Sweep                | -         |
|           |      | 0.0121     | Lower Limit                                                   | 3-45      |
|           |      | 3.6.28     | Group 4, APR 33 Carrier Loop Configuration                    |           |
|           |      |            | Register                                                      | 3-45      |
|           |      | 3.6.29     | Group 4, APR 34 Set to 0                                      | 3-48      |
|           |      | 3.6.30     | Group 4, APR 35 Decoder Configuration Register                | 3-49      |
|           |      | 3.6.31     | Group 4, APR 36 External Output Control Bits                  |           |
|           |      |            | and Reset Register                                            | 3-50      |
| Chapter 4 | Char | nnel Inter | faces and Data Control                                        |           |
|           | 4.1  | Data C     | ontrol and Clocking Schemes                                   | 4-2       |
|           | 4.2  | Channe     | el Data Input Interface                                       | 4-4       |
|           | 4.3  | Channe     | el Data Output Interface                                      | 4-5       |
|           | 4.4  | PLL Clo    | ock Generation                                                | 4-5       |
|           | 4.5  | Data Pa    | ath Output Configurations                                     | 4-12      |
|           |      | 4.5.1      | Descrambler Output                                            | 4-13      |
|           |      | 4.5.2      | Synchronization Stage 3 Output                                | 4-15      |
|           |      | 4.5.3      | Reed-Solomon Decoder Output                                   | 4-15      |
|           |      | 4.5.4      | Deinterleaver Output                                          | 4-16      |
|           |      | 4.5.5      | Synchronization Stage 2 Output                                | 4-17      |
|           |      | 4.5.6      | Viterbi Decoder Output                                        | 4-17      |
|           |      | 4.5.7      | Viterbi Depuncture/Synchronization Output                     | 4-18      |
|           |      | 4.5.8      | QPSK Demodulator Output                                       | 4-19      |
| Chapter 5 | Dem  | odulator   | Module Functional Description                                 |           |
|           | 5.1  | Overvie    | -                                                             | 5-1       |
|           | 5.2  | DC Off     | set Compensation and Coupling to ADC Output                   | 5-3       |
|           | 5.3  |            | tion Filters                                                  | 5-3       |
|           | 5.4  | Matche     | d Filter                                                      | 5-4       |
|           | 5.5  | Channe     | el Clock Recovery                                             | 5-4       |
|           |      | 5.5.1      | Input Decimation                                              | 5-5       |
|           |      | 5.5.2      | Clock Acquisition and Tracking Modes                          | 5-5       |
|           |      |            | · · · · · · · · · · · · · · · · · · ·                         |           |

|           |      | 5.5.3                | Output Symbol Clock                      | 5-8  |
|-----------|------|----------------------|------------------------------------------|------|
|           |      | 5.5.4                | Constraints on Data Rates                | 5-8  |
|           |      | 5.5.5                | Examples                                 | 5-9  |
|           | 5.6  | Carrier              | Synchronizer                             | 5-10 |
|           |      | 5.6.1                | Carrier Acquisition                      | 5-12 |
|           |      | 5.6.2                | Carrier Phase Tracking                   | 5-17 |
|           | 5.7  | Autom                | atic Gain Control (AGC)                  | 5-22 |
|           |      | 5.7.1                | ADC Range and Power Reference            | 5-22 |
|           |      | 5.7.2                | Power Control Loop                       | 5-23 |
|           |      | 5.7.3                | Power Level                              | 5-24 |
|           | 5.8  | Output               | Control                                  | 5-24 |
|           | 5.9  | Other                | Functions                                | 5-26 |
|           |      | 5.9.1                | Carrier Loop DC Offset Compensation      | 5-26 |
|           |      | 5.9.2                | External Controls                        | 5-27 |
|           |      | 5.9.3                | Hi-Z Mode on Functional Outputs          | 5-27 |
| Chapter 6 | Deco | oding Pi             | peline Synchronization                   |      |
|           | 6.1  |                      | ronization Scheme                        | 6-1  |
|           | 6.2  | Viterbi              | Decoder Synchronization                  | 6-2  |
|           | 6.3  | Reed-S               | Solomon Deinterleaver Synchronization    | 6-5  |
|           | 6.4  | Descra               | ambler Synchronization                   | 6-10 |
| Chapter 7 | The  | FEC Decoder Pipeline |                                          |      |
|           | 7.1  | Viterbi              | Decoder Module                           | 7-1  |
|           |      | 7.1.1                | Features                                 | 7-2  |
|           |      | 7.1.2                | Code Performance                         | 7-3  |
|           |      | 7.1.3                | Punctured Codes                          | 7-3  |
|           |      | 7.1.4                | Viterbi Bit Error Rate Monitor           | 7-6  |
|           | 7.2  | Deinte               | rleaver Module                           | 7-11 |
|           |      | 7.2.1                | Deinterleaver Block Diagram              | 7-12 |
|           |      | 7.2.2                | Deinterleaver Output                     | 7-13 |
|           | 7.3  | Reed-S               | Solomon Decoder                          | 7-14 |
|           |      | 7.3.1                | Terms and Concepts                       | 7-14 |
|           |      | 7.3.2                | Features                                 | 7-17 |
|           |      | 7.3.3                | Performance Analysis                     | 7-18 |
|           | 7.4  | Descra               | ambler Module Architecture and Operation | 7-19 |
|           | 7.5  | FEC M                | lodule Software Reset                    | 7-21 |
|           |      |                      |                                          |      |

| <ul><li>8.1 Electrical Requirements</li><li>8.2 AC Timing</li><li>8.3 L64704 Packaging</li></ul> |             |
|--------------------------------------------------------------------------------------------------|-------------|
| 5                                                                                                | 8-5<br>8-10 |
| 8.3 L64704 Packaging                                                                             | 8-10        |
|                                                                                                  |             |
| Appendix A Programming the L64704 Using the Serial Bus Protocol                                  |             |
| A.1 Serial Bus Protocol Overview                                                                 | A-1         |
| A.2 Programming the Slave Address Using the Serial                                               |             |
| Bus Interface                                                                                    | A-4         |
| A.3 Write Cycle Using the Serial Bus Interface                                                   | A-4         |
| A.4 Read Cycle Using the Serial Bus Interface                                                    | A-6         |
| Appendix B L64704 Application Notes                                                              |             |
| B.1 Controlling the L64704's BPSK/QPSK Demodulator Loop                                          | s B-1       |
| B.2 L64704 QPSK Demodulator Debugging Tips                                                       | B-4         |
| B.2.1 AGC Loop                                                                                   | B-4         |
| B.2.2 Clock Loop                                                                                 | B-5         |
| B.2.3 Carrier Loop                                                                               | B-6         |
| B.2.4 QPSK Demodulator Debugging Summary                                                         | B-7         |
| B.3 QPSK Demodulator Configuration Example                                                       | B-8         |
| B.3.1 Programming the L64704 QPSK Demodulator F<br>B-9                                           | egisters    |
| B.3.2 RC Values for Clock Loop                                                                   | B-16        |
| B.3.3 VCO Gains                                                                                  | B-16        |
| B.3.4 Low Data Rates                                                                             | B-17        |
| B.4 Configuring the L64704 FEC Decoder to the DVB                                                |             |
| Specifications                                                                                   | B-18        |
| Appendix C Oscillator Cells                                                                      |             |
| C.1 Introduction                                                                                 | C-1         |
| C.2 Requirements For Oscillator Circuits                                                         | C-2         |
| C.3 0 to 20 MHz Crystal Oscillator                                                               | C-2         |
| C.4 Higher Frequency Oscillators                                                                 | C-4         |
| C.5 Low Frequency Oscillation (kHz Range)                                                        | C-5         |

#### **Customer Feedback**

| Figures | 1.1  | L64704 Block Diagram                                | 1-2  |
|---------|------|-----------------------------------------------------|------|
|         | 1.2  | Set-Top Decoder Box Block Diagram                   | 1-3  |
|         | 1.3  | Typical Receiver Block Diagram with L64704          | 1-4  |
|         | 1.4  | Concatenated Decoding Performance for L64704        | 1-6  |
|         | 2.1  | L64704 Logic Diagram                                | 2-2  |
|         | 3.1  | Register-File Structure                             | 3-6  |
|         | 3.2  | Issue a Hard Reset                                  | 3-7  |
|         | 3.3  | Initialize APR0 and APR1 to Zero                    | 3-7  |
|         | 3.4  | Write Locations 0 and 1 in Group 4                  | 3-8  |
|         | 3.5  | Read Back Group 4                                   | 3-8  |
|         | 4.1  | L64704 Clocking: Internal PLL                       | 4-2  |
|         | 4.2  | L64704 Clocking: External PLL                       | 4-3  |
|         | 4.3  | Code Rate = 1/2 System                              | 4-3  |
|         | 4.4  | Code Rate = 3/4 System; Different OCLK and CLK      | 4-4  |
|         | 4.5  | CLK Reference to Channel Data Input                 | 4-4  |
|         | 4.6  | OCLK Reference to Channel Data Output               | 4-5  |
|         | 4.7  | FSTARTOUT Related to Symbols                        | 4-5  |
|         | 4.8  | PLL Clock Generation                                | 4-6  |
|         | 4.9  | PLL Clock Synthesis                                 | 4-7  |
|         | 4.10 | L64704 Functional Blocks in the Decoding Pipeline   | 4-13 |
|         | 4.11 | Descrambler Serial Output Waveforms                 | 4-14 |
|         | 4.12 | Descrambler Parallel Output Format                  | 4-14 |
|         | 4.13 | Synchronization Stage 3 Output Waveforms            | 4-15 |
|         | 4.14 | Reed-Solomon Decoder Output Waveforms               | 4-16 |
|         | 4.15 | Deinterleaver Output Waveforms                      | 4-16 |
|         | 4.16 | Synchronization Stage 2 Output Waveforms            | 4-17 |
|         | 4.17 | Viterbi Decoder Output Waveforms                    | 4-18 |
|         | 4.18 | Viterbi Depuncture/Synchronization Output Waveforms | 4-18 |
|         | 4.19 | QPSK Demodulator Output Waveforms                   | 4-19 |
|         | 5.1  | Demodulator Module and its Associated Circuitry     | 5-2  |
|         | 5.2  | Input Quantization with AC Coupling                 | 5-3  |
|         | 5.3  | Clock Recovery Loop                                 | 5-4  |
|         | 5.4  | Spectrum of Oversampled Signal                      | 5-9  |
|         | 5.5  | Carrier Recovery Loop                               | 5-11 |
|         | 5.6  | Frequency Sweeping                                  | 5-13 |
|         | 5.7  | SNR Threshold vs. ES/No                             | 5-17 |
|         | 5.8  | Carrier Loop Filter Schematic                       | 5-18 |

| 5.9  | PED Slope                                              | 5-19 |
|------|--------------------------------------------------------|------|
| 5.10 | Using CAR_PED Outputs                                  | 5-21 |
| 5.11 | Eye Pattern and ADC Range                              | 5-22 |
| 5.12 | AGC Loop Control                                       | 5-23 |
| 5.13 | Eye Pattern and Soft Decision Thresholds               | 5-25 |
| 6.1  | Synchronization Module                                 | 6-2  |
| 6.2  | Viterbi Decoder Synchronization                        | 6-3  |
| 6.3  | Phase Rotation for Synchronization                     | 6-4  |
| 6.4  | Reed-Solomon, Deinterleaver Synchronization            | 6-5  |
| 6.5  | Synchronization, Tracking, and Loss of Sync for 3      |      |
|      | Missed Sync Words                                      | 6-6  |
| 6.6  | Minimum and Maximum Number of States in the            |      |
|      | Acquisition Phase                                      | 6-7  |
| 6.7  | Minimum and Maximum Number of States in the            |      |
|      | Tracking Phase                                         | 6-8  |
| 6.8  | MPEG-2 Transport Packet                                | 6-8  |
| 6.9  | L64704 Transport Packet                                | 6-9  |
| 6.10 | Descrambler Synchronization                            | 6-10 |
| 6.11 | Synchronization, Tracking, and Loss of Synchronization |      |
|      | in the Descrambler                                     | 6-11 |
| 7.1  | Block Diagram of Viterbi Decoder Core                  | 7-2  |
| 7.2  | Code Performance for Viterbi Decoder                   | 7-3  |
| 7.3  | Puncturing and Depuncturing Block Diagram              | 7-4  |
| 7.4  | Puncture Pattern for Different Code Rates              | 7-5  |
| 7.5  | Block Diagram of Viterbi Bit Error Detection Circuit   | 7-8  |
| 7.6  | Percent Channel Symbol Errors vs. Eb/No for            |      |
|      | Rate = 1/2 Code                                        | 7-9  |
| 7.7  | Percent Channel Symbol Errors vs. Eb/No for            |      |
|      | Rate = $2/3$ Code                                      | 7-9  |
| 7.8  | Percent Channel Symbol Errors vs. Eb/No for            |      |
|      | Rate = $3/4$ Code                                      | 7-10 |
| 7.9  | Percent Channel Symbol Errors vs. Eb/No for            |      |
|      | Rate = $5/6$ Code                                      | 7-10 |
| 7.10 | Percent Channel Symbol Errors vs. Eb/No for            |      |
|      | Rate = 7/8 Code                                        | 7-11 |
| 7.11 | Interleaving/Deinterleaving Operation                  | 7-12 |
| 7.12 | Block Diagram of Deinterleaver Core                    | 7-13 |
| 7.13 | Deinterleaver Output Example                           | 7-13 |

| 7.14 | Code Word Structure                                       | 7-15 |
|------|-----------------------------------------------------------|------|
| 7.15 | Forward Error Correction Data Path                        | 7-15 |
| 7.16 | 122-bit Burst Example                                     | 7-17 |
| 7.17 | (255, 255-2T) Code Performance                            | 7-19 |
| 7.18 | Descrambler Block Diagram                                 | 7-20 |
| 7.19 | 15-bit Shift Register                                     | 7-20 |
| 7.20 | Inverting Sync Words in Descrambler                       | 7-21 |
| 8.1  | AC Test Load and Waveform for Standard Outputs            | 8-5  |
| 8.2  | AC Test Load and Waveform for 3-State Outputs             | 8-6  |
| 8.3  | L64704 Synchronous AC Timing                              | 8-6  |
| 8.4  | L64704 RESET Timing Diagram                               | 8-7  |
| 8.5  | L64704 Bus 3-State Delay Timing                           | 8-7  |
| 8.6  | L64704 Decoder Read Cycle                                 | 8-7  |
| 8.7  | L64704 Decoder Write Cycle                                | 8-8  |
| 8.8  | L64704 100-Pin PQFP Pinout                                | 8-11 |
| 8.9  | 100-Pin PQFP Mechanical Drawing (Sheet 1 of 2)            | 8-12 |
| A.1  | Quick Overview of the Serial Bus                          | A-2  |
| A.2  | Quick Overview of Serial Bus Write/Read Cycles            | A-3  |
| A.3  | General Call Structure                                    | A-4  |
| A.4  | Burst Write to Slave (Master-Transmitter, Slave-Receiver) | A-5  |
| A.5  | Single Read From Slave                                    | A-7  |
| B.1  | Flow Diagram of Microcontroller Monitoring External Loops | B-3  |
| B.2  | AGC Loop Control                                          | B-5  |
| C.1  | Simplest Oscillator                                       | C-1  |
| C.2  | Pierce Crystal Oscillator Circuit                         | C-2  |
| C.3  | A Third Overtone (Higher Frequency) Oscillator Circuit    | C-4  |
| C.4  | A Low Frequency Range (kHz) Oscillator Circuit            | C-5  |
| 3.1  | Register Overview                                         | 3-2  |
| 3.2  | Register Map                                              | 3-2  |
| 3.3  | Group 3 Register Map                                      | 3-20 |
| 3.4  | Group 4 Register Map                                      | 3-27 |
| 4.1  | CLK/SCLK Ratio                                            | 4-7  |
| 4.2  | Values for PLL_S, PLL_N, PLL_T, and PLL_M                 | 4-8  |
| 5.1  | M as a Function of CLK_DR and CLK_RATIO                   | 5-7  |
| 5.2  | Natural Frequency as a Function of M                      | 5-8  |
| 5.3  | Example of Data Rates                                     | 5-10 |
|      |                                                           |      |

Tables

| 5.4  | Example of Data Rates for Narrow SAW Filter              | 5-10 |
|------|----------------------------------------------------------|------|
| 5.5  | PWR_BW as a Function of Symbol Rate                      | 5-23 |
| 6.1  | Stage 2 Synchronization Values                           | 6-9  |
| 7.1  | Puncture Patterns for Various Code Rates                 | 7-4  |
| 7.2  | Viterbi Threshold Values                                 | 7-7  |
| 8.1  | L64704 Absolute Maximum Rating (Referenced to $V_{SS}$ ) | 8-2  |
| 8.2  | L64704 Recommended Operating Conditions                  | 8-2  |
| 8.3  | L64704 Capacitance                                       | 8-2  |
| 8.4  | L64704 DC Characteristics                                | 8-3  |
| 8.5  | L64704 Pin Description Summary                           | 8-4  |
| 8.6  | L64704 AC Timing Parameters                              | 8-8  |
| 8.7  | L64704 Ordering Information                              | 8-10 |
| 8.8  | Alphabetical Pin List for the 100-pin PQFP               | 8-10 |
| B.1  | QPSK Demodulator Loop Registers                          | B-2  |
| B.2  | PWR_LVL Register Setting                                 | B-4  |
| B.3  | QPSK Demodulator Loop Registers                          | B-6  |
| B.4  | $\omega_n$ for Fixed Rate Operation (Damping = 1)        | B-11 |
| B.5  | Group 4 Decoder Register Map                             | B-14 |
| B.6  | Group 4 Decoder Registers Actual Configuration           | B-15 |
| B.7  | Typical Clock and Carrier VCO Gains                      | B-16 |
| B.8  | CAR_PED Output Pins                                      | B-17 |
| B.9  | Group 4 Register Map                                     | B-18 |
| B.10 | Group 4 Actual Configuration                             | B-19 |
| C.1  | Component Values for the Circuit Shown in Figure C.2     | C-3  |
| C.2  | Component Values for the Circuit Shown in Figure C.3     | C-4  |
| C.3  | Component Values for the Circuit Shown in Figure C.4     | C-5  |

## Preface

|              | This book is the primary reference and technical manual for the L64704 Satellite Decoder. It contains a complete functional description for the L64704 and includes complete physical and electrical specifications for the L64704. |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Audience     | This document assumes that you have some familiarity with digital satellite communications, microprocessors, and related support devices. The people who benefit from this book are:                                                |
|              | <ul> <li>Engineers and managers who are evaluating the L64704 for possible<br/>use in a digital satellite receiver</li> </ul>                                                                                                       |
|              | <ul> <li>Engineers who are designing the L64704 into a digital satellite receiver</li> </ul>                                                                                                                                        |
| Organization | This document has the following chapters and appendix:                                                                                                                                                                              |
|              | <ul> <li>Chapter 1, Introduction, defines the general characteristics and<br/>capabilities of the L64704 Satellite Decoder.</li> </ul>                                                                                              |
|              | <ul> <li>Chapter 2, L64704 Signal Definitions, describes the characteristics<br/>of the L64704 signals that are used to interface with an external<br/>channel and microcontroller.</li> </ul>                                      |
|              | <ul> <li>Chapter 3, L64704 Registers, provides a summary of the registers<br/>and tables in the L64704.</li> </ul>                                                                                                                  |
|              | <ul> <li>Chapter 4, Channel Interfaces and Data Control, discusses the<br/>Input Channel and Output Channel interfaces and the circuitry that<br/>supports them.</li> </ul>                                                         |
|              | <ul> <li>Chapter 5, Demodulator Module Functional Description,<br/>describes the operation of the Demodulator portion of the Satellite<br/>Decoder.</li> </ul>                                                                      |

|                         | <ul> <li>Chapter 6, Decoding Pipeline Synchronization, discusses the<br/>mechanism for synchronizing the internal decoder modules to the<br/>incoming data stream.</li> </ul>        |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | <ul> <li>Chapter 7, The FEC Decoder Pipeline, describes the various logic<br/>modules that comprise the FEC decoding pipeline.</li> </ul>                                            |
|                         | <ul> <li>Chapter 8, L64704 Specifications, describes the electrical and<br/>mechanical characteristics of the L64704.</li> </ul>                                                     |
|                         | <ul> <li>Appendix A, Programming the L64704 Using the Serial Bus<br/>Protocol, provides information on how to program the L64704 using<br/>its Serial Bus protocol.</li> </ul>       |
|                         | <ul> <li>Appendix B, L64704 Application Notes, provides application infor-<br/>mation on connecting the L64704 in your circuit and programming it<br/>to meet your needs.</li> </ul> |
|                         | <ul> <li>Appendix C, Oscillator Cells, provides information on the oscillator<br/>cells used in the L64704, and how to design oscillators using these<br/>cells.</li> </ul>          |
| Related<br>Publications | L64002 MPEG-2 Audio/Video Decoder Technical Manual,<br>Order No. I14011                                                                                                              |
|                         | <i>L64007 MPEG-2, DVB and TSAT Transport Demultiplexer Technical Manual,</i> Document No. DB14-000007-00                                                                             |
|                         | <i>European Digital Video Broadcast Standard, DTVB 1110 Revision 7.</i><br>This document is available from:                                                                          |
|                         | DVB Project Office<br>European Broadcasting Union<br>Ancienne Route, 17A<br>Grand Saconnex<br>Geneva, Switzerland                                                                    |

| Conventions            | The first time a word or phrase is defined in this manual, it is <i>italicized</i> . |
|------------------------|--------------------------------------------------------------------------------------|
| Used in This<br>Manual | The following signal naming conventions are used throughout this manual:             |
|                        | $\Lambda$ A level similar trime that is true so called when the simulation $O(M)$    |

- ♦ A level-significant signal that is true or valid when the signal is LOW always has an overbar ( ) over its name.
- An edge-significant signal that initiates actions on a HIGH-to-LOW transition always has an overbar ( ) over its name.

The word *assert* means to drive a signal true or active. The word *deassert* means to drive a signal false or inactive.

Hexadecimal numbers are indicated by the prefix "0x" before the number—for example, 0x32CF. Binary numbers are indicated by a subscripted "2" following the number—for example, 0011.0010.1100.1111<sub>2</sub>.

Operations on registers are referred to using the binary numbers 0 and 1. Output signal levels are referred to by the designations HIGH and LOW. Example: Set the XCTR0 register bit to 1 to force the XCTR\_OUT0 pin HIGH.

# Chapter 1 Introduction

|                | This chapter introduces the L64704 Satellite Decoder from LSI Logic.<br>The L64704 is designed specifically to meet the needs of satellite broad-<br>cast digital TV.                                                                                                                                                                                                     |  |  |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                | The sections in this chapter are:                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|                | <ul> <li>Section 1.1, "General Description," provides an overview of the architecture of the L64704 Satellite Decoder.</li> </ul>                                                                                                                                                                                                                                         |  |  |  |  |
|                | <ul> <li>Section 1.2, "Typical Application," describes how the L64704 is used<br/>in a typical satellite decoder system.</li> </ul>                                                                                                                                                                                                                                       |  |  |  |  |
|                | <ul> <li>Section 1.3, "Features Summary," summarizes the main features of<br/>the L64704.</li> </ul>                                                                                                                                                                                                                                                                      |  |  |  |  |
| 1.1<br>General | The L64704 Satellite Decoder contains two main blocks: a BPSK/QPSK Demodulator and a Concatenated FEC decoder.                                                                                                                                                                                                                                                            |  |  |  |  |
| Description    | The BPSK/QPSK module performs binary and quadrature phase-shift keying (BPSK/QPSK) demodulation, a method of extracting a digital signal from a phase-modulated analog signal. The BPSK/QPSK module is designed specifically for a satellite broadcast digital TV receiver, and is compliant with the European digital video broadcast (DVB) standard (DTVB 1110 Rev. 7). |  |  |  |  |
|                | The FEC Decoder pipeline is a complete concatenated Forward Error<br>Correction decoder that utilizes a Viterbi inner code and a Reed-Solomon<br>outer code. The FEC decoding pipeline also contains all of the necessary<br>synchronization, deinterleaving, and scrambling functions for a complete<br>decoding solution.                                               |  |  |  |  |
|                | The L64704 is compliant with specifications of the "Baseline<br>Modulation/Channel Coding System" by the Digital Video Broadcast                                                                                                                                                                                                                                          |  |  |  |  |

(DVB) Association. LSI Logic fabricates the L64704 using its LCB500K, 3.3-volt, 0.5-micron, HCMOS process technology.

The L64704 provides maximum integration and flexibility for system designers at a minimum cost. The number of external components required to build a system is minimal; only a dual operational amplifier and passive resistors and capacitors are needed for the implementation of the clock and carrier loop filters.

Figure 1.1 shows a block diagram of the L64704.



1.2A typical application of the L64704 is satellite digital TV reception accord-Typicaling to the DVB 1110 Rev. 7 standard. Figure 1.2 shows the L64704 Sat-Applicationellite Decoder in a typical Satellite Receiver Set-Top Decoder box.



256K x 32

LSI Logic offers circuits that make up the most complex portions of the logic found in a Set-Top Decoder box. These circuits include the:

- ♦ L64704 Satellite Decoder
- ♦ L64007 MPEG-2 Transport Demultiplexer
- L64002 MPEG-2 Audio/Video Decoder

For more information on the other integrated circuits in the Set-Top Decoder box, see their associated manuals.

Figure 1.3 shows a block diagram of a satellite tuner that includes the L64704.



The receiver block receives the microwave channel data from the satellite dish, demodulates and decodes it, and outputs an MPEG-2 transport stream.

**1.3**This section summarizes the main features of the L64704. Subsequent<br/>chapters describe these features in more detail.**Summary** 

- Variable BPSK/QPSK demodulation from 2 to 62.5 Mbit/s
- Matched filter (square root raised cosine filter, roll-off factor of 35%)
- Decimation filters for input oversampling ratios of 2/T, 3/T, and 4/T
- Clock synchronization
- Carrier synchronization featuring a frequency sweep capability for signal acquisition
- Power estimation for AGC control
- Internal DC offset control
- Programmable Viterbi decoder module for rates 1/2, 2/3, 3/4, 5/6, 7/8
- (204/188) Reed-Solomon decoder
- Auto synchronization for Viterbi decoder
- Programmable synchronization for Deinterleaver, Reed-Solomon Decoder, and Descrambler
- FEC module flags uncorrectable frames by setting the ninth bit of the MPEG Transport packet.
- Bit Error monitoring for channel performance measurements
- Depth 12 deinterleaver
- Serial host interface compatible with the LSI Logic Serial Control bus interface
- Power down mode

Figure 1.4 shows a performance graph for the L64704 Satellite Decoder.



# Chapter 2 L64704 Signal Definitions

This chapter describes the signals that comprise the L64704 Satellite Decoder's interface to other components. This chapter is divided into seven sections that describe the various buses:

- Section 2.1, "Channel Interface," describes the input channel interface to the L64704.
- Section 2.2, "Channel Clock Recovery," lists the signals that make up the input channel clock recovery circuitry.
- Section 2.3, "Channel Data Output Interface," describes the signals that connect the channel data outputs to the MPEG demultiplexer.
- Section 2.4, "Phase-Locked Loop Interface," lists the signals that are used to connect the L64704 to an external Phase-Locked Loop.
- Section 2.5, "Carrier Synchronizer Loop Controls," provides a list of the signals that are used to synchronize the I/Q Down Converter circuitry.
- Section 2.6, "Microcontroller Interface," shows the signals that are used to connect the L64704 to an external microcontroller.
- Section 2.7, "Control Signals," describes the various signals that are necessary for the operation of the L64704, but do not fit into any of the categories above.

Figure 2.1 shows the logic symbol for the L64704.

Figure 2.1 L64704 Logic Diagram



| 2.1<br>Channel<br>Interface      | The Channel Interface is the input path to the L64704 Satellite Decoder.<br>The two signal buses RI[5:0] and RQ[5:0] are the I and Q streams from<br>the satellite tuner circuit. The CLK signal discussed in the Channel Clock<br>Recovery section is used to strobe in the data signals. The Channel<br>Interface is discussed in Section 4.2, "Channel Data Input Interface." |                                                                                                                                                                                                                                                  |  |  |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                  | RI[5:0]                                                                                                                                                                                                                                                                                                                                                                          | I Channel Data Input<br>Received I Channel data input bus.                                                                                                                                                                                       |  |  |
|                                  | RQ[5:0]                                                                                                                                                                                                                                                                                                                                                                          | Q Channel DataInputReceived Q Channel data input bus.                                                                                                                                                                                            |  |  |
| 2.2<br>Channel Clock<br>Recovery | The Channel Clock Recovery logic is the logic that recovers the clock for<br>the Channel Interface. Channel Clock recovery is discussed in<br>Section 5.5, "Channel Clock Recovery."                                                                                                                                                                                             |                                                                                                                                                                                                                                                  |  |  |
|                                  | CLK RI/Q Input Clock<br>CLK is a positive, edge-triggered clock that is used<br>strobe in input data. It is not used anywhere else i<br>L64704, and does not propagate past the Channel<br>Interface.                                                                                                                                                                            |                                                                                                                                                                                                                                                  |  |  |
|                                  | CLK_VCOP/N                                                                                                                                                                                                                                                                                                                                                                       | $\begin{array}{c} \textbf{Clock Loop VCO Control} & \textbf{Output} \\ These two differential signals are the Positive and Negative Sigma Delta ($\Sigma \Delta$) modulated output used to control the Channel Clock VCO frequency. \end{array}$ |  |  |
|                                  | XOIN                                                                                                                                                                                                                                                                                                                                                                             | Crystal Oscillator In Input<br>The XOIN pin is the crystal oscillator or external refer-<br>ence clock input.                                                                                                                                    |  |  |
|                                  | XOOUT                                                                                                                                                                                                                                                                                                                                                                            | Crystal Oscillator OutOutputThe XOOUT pin is the crystal oscillator output pin.                                                                                                                                                                  |  |  |

The Channel Data Output Interface is the output path from the L64704. Channel Data It is typically connected to the input of the Transport Demultiplexer in a **Output Interface** set-top decoder application. The Channel Data Output Interface is discussed in Section 4.3, "Channel Data Output Interface."

#### BCLKOUT Byte Clock Out

2.3

2-4

The BCLKOUT output signal is a strobe that indicates valid data bytes on the CO[7:0] bus when the L64704 is in Parallel Channel Output mode. The BCLKOUT signal cycles once per every valid output data byte and is used by the Transport Demultiplexer to latch output data from the L64704 at the BCLKOUT rate (rather than at the OCLK rate). BCLKOUT must be disregarded in Serial Channel Output mode.

#### CO[7:0] Channel Data Out

These signals form the decoded output data port. In Parallel Channel Output mode (OF = 1, Group 4, APR 12) the L64704 outputs the channel data as 8-bit wide parallel data on CO[7:0]. In Serial Channel Output mode (OF = 0) the L64704 outputs the channel data as serial data on CO0. It is latched on every byte or bit clock cycle. The chronological ordering in Serial Channel output mode is MSB oldest, LSB newest.

#### COE **Channel Output Enable** Input When asserted, COE enables the CO[7:0], ERROROUT, and FSTARTOUT pins. DVALIDOUT is unaffected by the COE pin and operation of the decoder continues

regardless of the state of this pin.

#### DVALIDOUT Valid Data Out

DVALIDOUT indicates that CO[7:0] contains the corrected channel data. New data is valid on the output when DVALIDOUT is HIGH. DVALIDOUT is not asserted during the propagated check and GAP bytes. This pin is set LOW after the FEC RST register bit (Group 4, APR 36) is asserted.

#### ERROROUT Error Detection Flag The L64704 asserts the ERROROUT pin to flag uncor-

rectable errors. The L64704 asserts the ERROROUT signal at the beginning of any frame that contains an uncorrectable error, and deasserts it at the end of the

### Output

#### Output

Output

#### Output

frame (if the error condition is removed). ERROROUT is exactly aligned with the output data stream. This pin is set HIGH after the FEC\_RST register bit (Group 4, APR 36) is asserted.

# FSTARTOUTFrame Start OutputOutputThe L64704 asserts FSTARTOUT during the first bit of<br/>every frame with valid data in Serial Channel Output<br/>mode and during the first byte in Parallel Channel Output<br/>mode. FSTARTOUT is valid only when DVALIDOUT is<br/>HIGH. This pin is set LOW after the FEC\_RST register<br/>bit (Group 4, APR 36) is asserted.

| 2.4<br>Phase-Locked<br>Loop Interface | Recovery cire<br>on the Viterb<br>into the L647 | Locked Loop (PLL) circuitry multiplies the Channel Clock<br>cuit SCLK signal by 2, 3, or 4 times the symbol rate, based<br>i code rate. The output from the PLL (PCLK) is brought back<br>704 on the OCLK pin to clock the FEC Decoder logic. Use<br>a discussed in Section 4.4, "PLL Clock Generation."                                                  |
|---------------------------------------|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                       | LP2                                             | Input to VCO Input<br>This pin is the input to the internal voltage controlled<br>oscillator. It is normally connected to the output of an<br>external RC timing circuit.                                                                                                                                                                                 |
|                                       | OCLK                                            | Decoder ClockInputThe positive edge of OCLK is a positive, edge-triggered<br>clock. The L64704 internally processes data (Viterbi<br>decoder, Synchronization, Descrambler, Deinterleaver,<br>Reed-Solomon Decoder) based on OCLK. All data out-<br>puts (DVALIDOUT, ERROROUT, FSTARTOUT, CO[7:0])<br>are referenced to OCLK. OCLK is independent of CLK. |
|                                       | PCLK                                            | PLL Clock OutputOutputThe L64704's internal PLL clock synthesis module generates the clock signal PCLK. The PLL is driven by the<br>SCLK internal signal (QPSK symbol clock). The PLL<br>clock synthesis module can be configured to generate a<br>PCLK rate that is appropriate for all Viterbi code rates<br>specified under the DVB standard.          |
|                                       | PLLAGND                                         | PLL Analog GroundInputAnalog ground pin for the PLL module. This pin is nor-<br>mally connected to the system ground plane.                                                                                                                                                                                                                               |

|                                | PLLVDD       | PLL Power Input<br>Power supply pin for the PLL module. This pin is normally<br>connected to the system power (V <sub>DD</sub> ) plane.                                                                                                                                                                                                                                                                                                                                            |
|--------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                | PLLVSS       | PLL Ground Input<br>Power supply pin for the PLL module. This pin is normally<br>connected to the system ground plane.                                                                                                                                                                                                                                                                                                                                                             |
| 2.5<br>Carrier<br>Synchronizer | Down Convert | ronizer Loop controls are used to synchronize the I/Q<br>er circuitry. Carrier Synchronizer Loop controls are dis-<br>tion 5.6, "Carrier Synchronizer."                                                                                                                                                                                                                                                                                                                            |
| Loop Controls                  | CAR_DCLKP/   | VCO Prescaler Input         Input           The CAR_DCLK pins are differential inputs for the pre-<br>scaled (divided) Carrier VCO clock (typically = VCO<br>frequency / 32).                                                                                                                                                                                                                                                                                                      |
|                                | CAR_PED[1:0  | <b>Carrier Phase Error Detector</b><br>These pins are the 2-bit outputs from the Phase Error<br>Detector. You use the CAR_PED outputs for carrier loop<br>implementation in combination with an external digital to<br>analog converter. It should be used when operating at<br>rates less than 5 Mbaud.                                                                                                                                                                           |
|                                | CAR_VCO1P/   | N       Output         When CAR_OUT_SEL (Group 4, APR 33) is set to 0, these pins are the Positive/Negative ΣΔ modulated outputs that control the carrier VCO frequency.       CAR_VCO1P/N feed external RC circuit number 1. A LOW output decreases the carrier VCO frequency. A HIGH output increases the carrier VCO frequency. A high impedance level maintains the carrier VCO frequency. When CAR_OUT_SEL is set to 1, these pins carry the CAR_PED.2 and CAR_PED.3 signals. |
|                                | CAR_VCO2P/   | N         Output           Carrier Loop VCO Control 2         Output           When CAR_OUT_SEL (Group 4, APR 33) is set to 0, these pins are the Positive/Negative ΣΔ modulated outputs that control the carrier VCO frequency.         CAR_VCO2P/N feed external RC circuit number 2. A LOW output decreases the carrier VCO frequency. A                                                                                                                                        |

HIGH output increases the carrier VCO frequency. A high impedance level maintains the carrier VCO frequency. When CAR\_OUT\_SEL is set to 1, these pins carry the CAR\_PED.4 and CAR\_PED.5 signals.

# PWRPPower ControlOutputThe power control signal is the positive $\Sigma\Delta$ modulated<br/>output used for power control. This signal can drive an<br/>external passive RC filter that feeds the gain control<br/>stage.

#### SYNC/SCLK Synchronization Status Flag Output

When the SYNC/SCLK bit (Group 4, APR 14) is set to 0, the SYNC/SCLK pin indicates the synchronization status for one of three synchronization modules in the L64704 (Viterbi Decoder sync, DI/RS sync, Descrambler sync). When HIGH the SYNC/SCLK output indicates the synchronization has been achieved for the chosen sync module. When LOW, the SYNC/SCLK output indicates an outof-synchronization condition.

When the SYNC/SCLK bit is set to 1, the SYNC/SCLK pin carries the SCLK signal that is used to clock the external DAC during low baud rate operation. See Section 5.6.2.3, "Low Baud Rate Operation" for more information.

| 2.6<br>Microcontroller<br>Interface | The Microcontroller Interface connects the L64704 to a microcontroller. |                                                                                                                                                                                                                                                                                                 |  |  |
|-------------------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                     | A[2:0]                                                                  | AddressInput $A[2:0]$ comprise the decoder address bus. The addressbus is used in conjunction with an eight-bit data bus $D[7:0]$ , a read/write strobe (READ), a chip select strobe $(\overline{CS})$ , and an address strobe ( $\overline{AS}$ ) to select, read andwrite internal registers. |  |  |
|                                     | AS                                                                      | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                            |  |  |
|                                     | <u>CS</u>                                                               | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                                                                                                                                                                            |  |  |

latch the data from the L64704 on the rising edge of  $\overline{CS}$ . During a write cycle,  $\overline{CS}$  must go LOW prior to data being valid from the controller to the L64704. After the data has met the minimum setup time, the microcontroller takes  $\overline{CS}$  HIGH to strobe the data. There is a minimum write time to allow for internal synchronization. Setup and hold times are measured with respect to the falling edge of  $\overline{CS}$ .

- D[7:0] Data Bus Bidirectional D[7:0] is the bidirectional data bus; it is the input data bus when data is written to the chip and the data output bus when the chip is read in Parallel Host Interface mode (HOST\_MODE pin is HIGH). The data lines are 3-stated when not being read or written. When Serial Host Interface mode is selected (HOST\_MODE pin is LOW), D0 is used as the Serial Clock signal to synchronize the transfer of serial data on the SDATA pin. The remaining seven bits of the data bus function as the slave address.
  - DTACK
     Data Acknowledge
     Output

     Data Acknowledge is an active-LOW output indicating that the transaction on the D[7:0] bus has been completed.
     Output
  - HOST\_MODE Serial or Parallel Host Interface Select Input When HOST\_MODE is LOW, it selects the Serial Host Interface mode; when HIGH, it selects the Parallel Host Interface mode.
  - INTInterruptOutputThe L64704 assertsINT LOW when an internal<br/>unmasked interrupt flag is set.INT remains asserted as<br/>long as the interrupt condition persists and the interrupt<br/>flag is not masked.READRead/Write StrobeInput<br/>The microcontroller drives READ HIGH to indicate that<br/>the current transaction is a read from the L64704, and
  - SDATA
     Serial Host Interface Data
     Bidirectional

     This bidirectional pin is the data input or output pin when
     Serial Host Interface mode is selected (HOST\_MODE is LOW).

LOW to indicate that it is a write to the L64704.

| 2.7                    | These signals control the operation of the L64704. They are not associ- |
|------------------------|-------------------------------------------------------------------------|
| <b>Control Signals</b> | ated with any particular interface.                                     |

| IDDTN | Test Pin                                         | Input    |
|-------|--------------------------------------------------|----------|
|       | IDDTN is an LSI Logic internal test pin. Connect | this pin |
|       | LOW for normal operation.                        |          |
| RESET | Reset                                            | Input    |

| ESET | Reset Input                                                  |
|------|--------------------------------------------------------------|
|      | This active-HIGH signal resets all internal data paths.      |
|      | Reset timing is asynchronous to the device clocks. Reset     |
|      | does not affect the configuration registers. It performs the |
|      | same operation as the reset bits specified in Section        |
|      | 3.6.31, "Group 4, APR 36 External Output Control Bits        |
|      | and Reset Register."                                         |
|      |                                                              |

XCTR\_IN **Control Input Pin** Input The XCTR\_IN pin is an external input control pin. It is sensed by reading the corresponding bit in the Group 3, APR 6 register.

#### XCTR\_OUT[3:0]

#### **Control Output Pins**

#### Output The XCTR\_OUT[3:0] pins are external output control pins. They are set by programming the corresponding bits in the Group 4, APR 36 register.

# Chapter 3 L64704 Registers

This chapter discusses the L64704 internal registers. It also provides a description of the internal memory mapping and describes how to access these registers from the system interface. This chapter is intended primarily for system programmers who are developing software drivers.

This chapter contains the following sections:

- Section 3.1, "L64704 Register Overview," provides an overview of the registers contained within the L64704.
- Section 3.2, "Reset and How It Affects Registers," describes the three separate methods of resetting the L64704 and how each method affects the registers.
- Section 3.3, "Group 0, 1 Address Pointer Register," describes how to address and use the Address Pointer Register.
- Section 3.4, "Group 2 Registers," provides information on the use of the System Mode and System Status Registers.
- Section 3.5, "Group 3 Registers," describes how to read and use the Status Registers.
- Section 3.6, "Group 4 Registers" provides information on programming and using the L64704's Configuration Registers.

This chapter provides complete information on how to use these registers, but does not provide information on how to program the registers for a specific application. See Appendix B, "L64704 Application Notes" for applications information. The L64704 registers and memory resources are divided into five groups: Group 0 through Group 4. Group 0 and 1 contain the Address Pointer Register
 Pointer Register. This pointer is used to address the registers in Groups 2, 3 and 4. Group 2 addresses the System Status Register when read and the System Mode Register when written. Group 3 contains the status counters, and Group 4 contains the configuration registers (See Table 3.1).

Table 3.1 Register Ove

| Overview | Group | Function                      | Page |
|----------|-------|-------------------------------|------|
|          | 0     | Address Pointer Register, LSB | 3-10 |
|          | 1     | Address Pointer Register, MSB | 3-10 |
|          | 2     | System Mode/Status Registers  | 3-11 |
|          | 3     | Status Registers              | 3-20 |
|          | 4     | Configuration Registers       | 3-26 |
|          | 5     | Reserved                      |      |
|          | 6     | Reserved                      |      |
|          | 7     | Reserved                      |      |

Table 3.2 shows the complete Register Map for the L64704 Satellite Decoder.

#### Table 3.2 Register Map

| Group    | APR            | Bit(s) | R/W | Description                            | Acronym     | Page |  |  |
|----------|----------------|--------|-----|----------------------------------------|-------------|------|--|--|
| 0        | N/A            | 7:0    | W   | Address Pointer Register LSB           | APR         | 3-10 |  |  |
| 1        | N/A            | 7:0    | W   | Address Pointer Register MSB           | APR         | 3-10 |  |  |
| 2        | 0              | 7:0    | R   | System Status Register [7:0]           | STS         | 3-16 |  |  |
|          |                | 7:0    | W   | System Mode Register [7:0]             | SMR         | 3-11 |  |  |
|          | 1              | 7:0    | R   | System Status Register [15:8]          | STS         | 3-16 |  |  |
|          |                | 7:0    | W   | System Mode Register [15:8]            | SMR         | 3-11 |  |  |
| 3        | 0              | 7:0    | R   | Reed-Solomon Corrected Error Count     | CEC[7:0]    | 3-21 |  |  |
|          | 1              | 7:0    | R   | Reed-Solomon Corrected Error Count     | CEC[15:8]   | 3-21 |  |  |
|          | 2              | 7:0    | R   | Reed-Solomon Uncorrected Error Count   | UEC[7:0]    | 3-21 |  |  |
|          | 3              | 7:0    | R   | Reed-Solomon Uncorrected Error Count   | UEC[15:8]   | 3-21 |  |  |
|          | 4              | 7:0    | R   | Viterbi Bit Error Rate Count Low Byte  | VBERC[7:0]  | 3-22 |  |  |
|          | 5              | 7:0    | R   | Viterbi Bit Error Rate Count High Byte | VBERC[15:8] | 3-22 |  |  |
| (Sheet ? | (Sheet 1 of 4) |        |     |                                        |             |      |  |  |

#### Table 3.2 (Cont.) Register Map

| Group    | APR     | Bit(s) | R/W | Description                              | Acronym        | Page |
|----------|---------|--------|-----|------------------------------------------|----------------|------|
| 3        | 6       | 7      | R   | Demodulator Signal to Noise Ratio        | Demod_SNR      | 3-22 |
|          |         | 6      | R   | External Control Bit Input               | XCTR_IN        | 3-22 |
|          |         | 5:0    | R   | Measured VCO Frequency, Upper Bits       | CAR_VCOF[13:8] | 3-22 |
|          | 7       | 7:0    | R   | Measured VCO Frequency, Lower Byte       | CAR_VCOF[7:0]  | 3-23 |
|          | 8       | 7:0    | R   | AGC Loop Voltage Meter                   | PWR_LVL[7:0]   | 3-23 |
|          | 9       | 5      | R   | Carrier Frequency Lock Flag              | CAR_LCF        | 3-23 |
|          |         | 4      | R   | Carrier Phase Lock Flag                  | CAR_LC         | 3-23 |
|          |         | 3      | R   | Clock Frequency Lock Flag                | CLK_LCF        | 3-23 |
|          |         | 2      | R   | Stage 3 Synchronization Flag             | S3             | 3-23 |
|          |         | 1      | R   | Stage 2 Synchronization Flag             | S2             | 3-23 |
|          |         | 0      | R   | Stage 1 Synchronization Flag             | S1             | 3-23 |
|          | 10      | 5:0    | R   | RI Input Readback                        | RI             | 3-25 |
|          | 11      | 5:0    | R   | RQ Input Readback                        | RQ             | 3-26 |
| 4        | 0       | 5:0    | R/W | Phase-Locked Loop Config. Param. N       | PLL_N[5:0]     | 3-28 |
|          | 1       | 5:0    | R/W | Phase-Locked Loop Config. Param. S       | PLL_S[5:0]     | 3-28 |
|          | 2       | 7      | R/W | (I, -Q) Symbol Format                    | IMQ            | 3-29 |
|          |         | 5      | R/W | QPSK/BPSK Format Select                  | QB             | 3-29 |
|          |         | 4:0    | R/W | Phase-Locked Loop Config. Param. T       | PLL_T[4:0]     | 3-29 |
|          | 3       | 7:5    | R/W | Viterbi Code Rate                        | VCR[2:0]       | 3-30 |
|          |         | 4      | R/W | Transport Error Indicator Select         | TEI            | 3-30 |
|          |         | 3      | R/W | Select SYNC 2 Modified Algorithm         | SYNC2_MOD      | 3-30 |
|          |         | 1:0    | R/W | VCO Frequency Range for PLL Module       | PLL_M[1:0]     | 3-30 |
|          | 4       | 7:0    | R/W | Viterbi Maximum Data Bit Count 1         | VMDC1[7:0]     | 3-31 |
|          | 5       | 7:0    | R/W | Viterbi Maximum Data Bit Count 2, Low    | VMDC2[7:0]     | 3-31 |
|          | 6       | 7:0    | R/W | Viterbi Maximum Data Bit Count 2, Middle | VMDC2[15:8]    | 3-31 |
|          | 7       | 7:0    | R/W | Viterbi Maximum Data Bit Count 2, High   | VMDC2[23:16]   | 3-31 |
|          | 8       | 7:0    | R/W | Viterbi Maximum Bit Error Count          | VMBEC[7:0]     | 3-32 |
|          | 9       | 7:0    | R/W | Synchronization Word                     | Sync[7:0]      | 3-32 |
|          | 10      | 7      | R/W | Bit Error Rate Monitor                   | BER            | 3-33 |
|          |         | 1:0    | R/W | Mismatching Bits, Tracking Mode, Sync2   | L[1:0]         | 3-33 |
| (Sheet 2 | 2 of 4) |        | -   | •                                        |                |      |

#### Table 3.2 (Cont.) Register Map

| Group    | APR     | Bit(s) | R/W | Description                                                      | Acronym              | Page |
|----------|---------|--------|-----|------------------------------------------------------------------|----------------------|------|
| 4        | 11      | 7      | R/W | BCLKOUT Format                                                   | BF                   | 3-34 |
|          |         | 5:4    | R/W | Synchronization Status Select                                    | SSS[1:0]             | 3-34 |
|          |         | 3:2    | R/W | Synchronization States, Acquisition Mode                         | SSA[1:0]             | 3-34 |
|          |         | 1:0    | R/W | Synchronization States, Tracking Mode                            | SST[1:0]             | 3-34 |
|          | 12      | 7:5    | R/W | Symbol Size for Viterbi Bypass Mode                              | BPS[2:0]             | 3-36 |
|          |         | 3      | R/W | Descrambler Output Format                                        | OF                   | 3-36 |
|          |         | 2:0    | R/W | Output Selector, OS[2:0]                                         | OS[2:0]              | 3-36 |
|          | 13      | 7:0    | W   | Reset for PLL Module                                             | PLL_RESET            | 3-37 |
|          | 14      | 7      | R/W | SYNC/SCLK Selector Bit                                           | SYNC/SCLK            | 3-37 |
|          |         | 4      | R/W | Functional Outputs 3-stated                                      | F_OUT_HiZ            | 3-37 |
|          |         | 3      | R/W | CLK_LCF_Suppress in Timing Error<br>Detector                     | CLK_LCF_<br>Suppress | 3-37 |
|          |         | 2      | R/W | Clock Outputs Polarity Swap                                      | CLK_VCO_SWAP         | 3-37 |
|          |         | 1:0    | R/W | Decimation Filter Select                                         | CLK_DR[1:0]          | 3-37 |
|          | 15      | 6      | R/W | PCLK Bypass                                                      | PCLK_BP              | 3-39 |
|          |         | 4      | R/W | Power-Down                                                       | PD                   | 3-39 |
|          |         | 3:0    | R/W | Reference Period for Clock AFC                                   | CLK_RP[3:0]          | 3-39 |
|          | 16      | 7:0    | R/W | CLK Input Nominal Frequency, Upper                               | CLK_NF[15:8]         | 3-40 |
|          | 17      | 7:0    | R/W | CLK Input Nominal Frequency, Lower                               | CLK_NF[7:0]          | 3-40 |
|          | 18      | 2:0    | R/W | Input Decimation Factor for RI & RQ<br>Inputs                    | CLK_RATIO[2:0]       | 3-40 |
|          | 19      | 7:0    | R/W | Reference Power Level                                            | PWR_REF[7:0]         | 3-41 |
|          | 20      | 2      | R/W | Internal DC Offset Compensation on I and<br>Q Signals            | INT_DC               | 3-41 |
|          |         | 1:0    | R/W | Power Estimation Bandwidth                                       | PWR_BW[1:0]          | 3-41 |
|          | 21      | 7:0    | R/W | Scale Factor for DEMI and DEMQ Outputs                           | SCALE[7:0]           | 3-42 |
|          | 22      | 7:0    | R/W | SNR Estimator Threshold                                          | SNR_THS[7:0]         | 3-42 |
|          | 23      | 7:0    | R/W | Carrier Loop DC Offset Comp. Value                               | CAR_OFFSET[7:0]      | 3-42 |
|          | 24      | 3:0    | R/W | Reference Period for Carrier Frequency (CAR_DCLKP/N) Measurement | CAR_RP[3:0]          | 3-43 |
|          | 25      | 7:0    | R/W | Gain of Carrier Loop Filter (P Term)                             | CAR_KP[7:0]          | 3-43 |
|          | 26      | 7:0    | R/W | Gain of Carrier Loop Filter (D Term)                             | CAR_KD[7:0]          | 3-43 |
| (Sheet 3 | 3 of 4) |        |     |                                                                  |                      |      |

Table 3.2 (Cont.) Register Map

| Group    | APR     | Bit(s)                                   | R/W | Description                                           | Acronym        | Page |
|----------|---------|------------------------------------------|-----|-------------------------------------------------------|----------------|------|
| 4        | 27      | 7:0                                      | R/W | Threshold for Carrier Lock Detector                   | CAR_THSL[7:0]  | 3-44 |
|          | 28      | 7:0                                      | R/W | Sweep Rate for Carrier Sweep                          | CAR_SWR[7:0]   | 3-44 |
|          | 29      | 5:0                                      | R/W | Upper Sweep Limit for Carrier Sweeping,<br>Upper Bits | CAR_USWL[13:8] | 3-44 |
|          | 30      | 7:0                                      | R/W | Upper Sweep Limit for Carrier Sweeping,<br>Lower Byte | CAR_USWL[7:0]  | 3-44 |
|          | 31      | 5:0                                      | R/W | Lower Sweep Limit for Carrier Sweeping,<br>Upper Bits | CAR_LSWL[13:8] | 3-46 |
|          | 32      | 7:0                                      | R/W | Lower Sweep Limit for Carrier Sweeping,<br>Lower Byte | CAR_LSWL[7:0]  | 3-46 |
|          | 33      | 7                                        | R/W | Swap Carrier Sweep Direction                          | CAR_SWP_SWP    | 3-46 |
|          |         | 6                                        | R/W | CAR_VCO Swap Outputs Polarity                         | CAR_VCO_SWAP   | 3-46 |
|          |         | 5                                        | R/W | CAR_VCO2N/P Outputs Active or 3-state                 | CAR_VCO2N/P    | 3-46 |
|          |         | 4                                        | R/W | CAR_VCO1N/P Outputs Active or 3-state                 | CAR_VCO1N/P    | 3-46 |
|          |         | 3                                        | R/W | Carrier Loop Output Selector                          | CAR_OUT_SEL    | 3-46 |
|          |         | 2                                        | R/W | Carrier Phase Error Detector Select                   | CAR_PED_SEL    | 3-46 |
|          |         | 1                                        | R/W | Carrier Loop Open                                     | CAR_OPEN       | 3-46 |
|          |         | 0                                        | R/W | Sweep On/Off for Carrier Loop                         | CAR_SW         | 3-46 |
|          | 34      | 7:5                                      | R/W | Set to 0                                              | Set to 0       | 3-49 |
|          | 35      | 5 7 R/W Signal to Noise Estimator On/Off |     | SNR_EST                                               | 3-50           |      |
|          |         | 6                                        | R/W | Constellation Selector                                | CON_SEL        | 3-50 |
|          |         | 4                                        | R/W | Frequency/Phase Lock Detector Length                  | FP_LOCK_LEN    | 3-50 |
|          |         | 0                                        | R/W | Input Format Selector                                 | I_FORMAT       | 3-50 |
|          | 36      | 2:5                                      | R/W | External Control Output Bits                          | XTCR[3:0]      | 3-51 |
|          |         | 1                                        | R/W | QPSK Demodulator Software Reset                       | DEMOD_RST      | 3-51 |
|          |         | 0                                        | R/W | FEC Decoder Software Reset                            | FEC_RST        | 3-51 |
| (Sheet 4 | 4 of 4) |                                          |     |                                                       |                |      |





To reduce the number of memory locations occupied by the L64704 in microcontroller memory, the L64704 uses an Address Pointer Register (APR). The APR has an auto-increment feature that simplifies the initialization procedure and reduces the number of memory cycles needed to read or write the registers. The address pointer and auto-increment feature are used whenever you access Groups 2, 3, and 4. The L64704 automatically points to the next register entry after you complete an access to one of these groups. When configuring or reading the configuration of groups 3 and 4, you will find it easier to initially set APR0 and APR1 to zero and let the auto-increment mechanism step through all the locations within the group.

For example: to access the PLL\_N configuration register 0 (Group 4, APR 0), first set APR0 = APR1 =  $0_2$  by writing a zero to addresses 0 and 1, then set A[2:0] to  $100_2$ . Address A[2:0] selects Group 4 of the six APR groups.

Internally, the L64704 has an 8-bit architecture. Most registers are eight bits wide, while some are either 16- or 24-bits wide. All registers are memory-mapped to the system with 8-bit resolution. When you are accessing a register that is wider than 8 bits, you must read or write two or three 8-bit sections: the least-significant byte (LSB) the middle-significant byte (MB) and the most-significant byte (MSB). Each 8-bit section is assigned a specific address, and therefore requires an individual memory cycle during programming.

| 3.1.1<br>Parallel Host<br>Mode Register<br>Operations | The L64704 is addressable through either a serial or a parallel host interface. The interface used depends on the value of the HOST_MODE pin (HIGH: Parallel Host Interface mode, LOW: Serial Host Interface mode) when the L64704 is reset. The mode, however, cannot be changed once the part is in operation. This section shows the steps required to read and write the L64704's registers when you are in Parallel Host Interface mode. Serial Host Interface mode is discussed in Section 3.1.2, "Programming Using the Serial Interface." |
|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                       | The following diagrams demonstrate read and write operation through the parallel microprocessor interface.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                       | Note: OCLK must run throughout the initialization process.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                       | Step 1. Issue a hard reset to the chip (Figure 3.2). Wait for t <sub>WK</sub> , 280 OCLK cycles, before the next step.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Figure 3.2<br>Issue a Hard<br>Reset                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                       | RESET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                       | Step 2. Set APR0 and APR1 to zero by writing a zero to addresses 0 and 1. (See Figure 3.3).                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Figure 3.3<br>Initialize APR0 and<br>APR1 to Zero     | <u>cs</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                       | D[7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                       | ĀS////                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                       | A[2:0] X 0 X 1 X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                       | READ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                       | DTACK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

Step 3. Write to the Configuration registers in Group 4. Start from location zero, and let the auto-increment mechanism advance to the next location with every low-to-high transition of  $\overline{CS}$ .

Because the APR registers were both initialized to zero, the first location written is zero, the second location will be one, and so on.

Figure 3.4 and Figure 3.5 present the first two write operations out of the 37 required operations described above.



Step 4. You can also choose to read back the L64704's configuration. This is demonstrated in Figure 3.5. You can set APR0 and APR1 to zero, as discussed in Step 2 and step through the configuration locations. The READ signal is asserted, and the auto-increment mechanism selects location 0, then location 1, etc.



Data is valid for a period  $t_{DELD}$  after  $\overline{CS}$  goes low.

Figure 3.4

Write Locations 0 and 1 in Group 4

| 3.1.2<br>Programming<br>Using the Serial<br>Interface | Setting the HOST_MODE pin LOW during reset places the L64704 in<br>Serial Host Interface mode. When the L64704 is addressed using the<br>serial interface, it must first be programmed with a 7-bit slave address<br>before any other read or write cycles. Appendix A, "Programming the<br>L64704 Using the Serial Bus Protocol, " contains a detailed description<br>of the protocol used when programming the L64704 in Serial Host<br>Interface mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 3.2<br>Reset and How<br>It Affects<br>Registers       | <ul> <li>There are three separate resets available on the L64704; the hardware RESET pin, the DEMOD_RST register bit and the FEC_RST register bit (Group 4, APR 36). Each affects the registers differently:</li> <li>Toggling the hardware RESET pin resets all of the Group 2 and Group 3 registers. Registers in Group 4 are unaffected.</li> <li>Setting the DEMOD_RST bit in the External Output Control Bits and Reset Register (Group 4, APR 36) affects only the bits in Group 3 registers that are directly concerned with the demodulator circuitry.</li> <li>Setting the FEC_RST bit in the External Output Control Bits and Reset Register (Group 4, APR 36) resets the System Mode/Status registers (Group 2) and any bits in Group 3 registers that are directly concerned with the demodulator circuitry.</li> <li>Registers in Group 4 are unaffected by any of these reset operations. Group 4 registers appear random immediately after power-up, and retain their last known value after any of the three reset operations listed above.</li> <li>The following steps should be followed when resetting the L64704:</li> <li>Issue an active HIGH reset pulse to the RESET pin.</li> <li>Program the Configuration (Group 4) registers to their proper values.</li> <li>Issue a soft reset by setting the DEMOD_RST bit and the FEC_RST bits to 1 (Group 4, APR 36). These bits are self-resetting, and do not have to be cleared.</li> <li>Wait the amount specified by the parameter t<sub>WK</sub> (see Figure 8.4).</li> <li>Start the L64704.</li> </ul> |  |  |

| 3.3<br>Group 0, 1<br>Address Pointer<br>Register | The Address Pointer Register (APR) is a 13-bit R/W register that points to the registers in Groups 2, 3, and 4. It is accessed when A[2:0] = $000_2$ and $001_2$ . Before accessing a register location from Group 2, 3, or 4, you must initialize the APR with the address of the first register entry that you are going to read or write. The APR automatically increments after reading or writing a byte within a Group 2, 3, or 4 register (A[2:0] = $010_2$ , $011_2$ or $100_2$ ). |
|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                  | 011 <sub>2</sub> or 100 <sub>2</sub> ).                                                                                                                                                                                                                                                                                                                                                                                                                                                    |



Two consecutive writes are required to load the complete APR. The first write is to Group 0 to load the eight LSBs, the second to Group 1 to load the five MSBs. The APR can be read as well as written.



The unused bits in these registers are reserved for LSI internal test procedures and future expansion and should always be set to zero.

To access a Group 3 or 4 register:

- Place the address of the lower byte of the register that you need to address into the APR.
- Read or write the lower byte of the register using the Group 3 register address (0x011) or Group 4 register address (0x100).
- If the register is a 16-bit register, just perform another read or write to the group register address to access the second byte. The APR increments automatically.

When you are through, the APR will automatically point to the next register in the group.

Group 2 contains two 16-bit registers; the System Mode Register and the System Status Register. The System Mode Register is accessed by writing the Group 2 address, and the System Status Register is accessed by reading the Group 2 address. Because the L64704 has an 8-bit architecture, each 16-bit register is accessed as two 8-bit registers:



The microcontroller accesses these registers by setting  $A[2:0] = 010_2$ . It can access these registers at any point during Satellite Decoder operation without interrupting the internal processing unit.

<u>Note:</u> The Phase-Locked Loop must be locked for the status signals to be valid.

3.4.1 The 16-bit System Mode Register (SMR) is a write-only register that allows the external microcontroller to control the L64704. Bits [15:8] of the register enable interrupts for the Demodulator and bits [7:0] of the register enable interrupts for the FEC module.

Because the SMR is arranged as two 8-bit registers, the microcontroller must perform two consecutive writes to the register address. The lower eight bits of the APR must be set to 0x00 before accessing the SMR. The eight LSBs of the SMR are accessed first. The auto-increment mechanism toggles the Address Pointer Register after the first access so that the next write goes to the MSB. If you only want to write the upper byte, you can set APR = 0x01 before the write operation.

The following register diagram shows the bit organization of SMR[15:8]. Descriptions of the fields follow the register diagram. The L64704 sets all the bits in SMR[15:8] to zero after a software or a hardware reset.

| APR | D15      | D14      | D13       | D12      | D11       | D10      | D9         | D8        |
|-----|----------|----------|-----------|----------|-----------|----------|------------|-----------|
| 1   | FS_UL_IE | FS_LL_IE | CF_LLK_IE | CF_LK_IE | CP_LLK_IE | CP_LK_IE | AFC_LLK_IE | AFC_LK_IE |

FS\_UL\_IE Freq. Sweep Upper Limit Reached Interrupt Enable 8 The microcontroller sets FS\_UL\_IE to enable an interrupt when the Frequency Sweep has reached its upper limit. The L64704 always sets the FS\_UL bit in STS[15:8] when this condition occurs.

| FS_UL_IE | Definition                                                         |
|----------|--------------------------------------------------------------------|
| 0        | Disable Interrupt for Frequency Sweep Upper<br>Limit Reached       |
| 1        | Enable Interrupt for Frequency Sweep Upper<br>Limit Reached Detect |

FS\_LL\_IE Freq. Sweep Lower Limit Reached Interrupt Enable 9 The microcontroller sets FS\_LL\_IE to enable an interrupt when the Frequency Sweep has reached its lower limit. The L64704 always sets the FS\_LL bit in STS[15:8] when this condition occurs.

#### FS\_LL\_IE Definition

| 0 | Disable Interrupt for Frequency Sweep Lower<br>Limit Reached Detect |
|---|---------------------------------------------------------------------|
| 1 | Enable Interrupt for Frequency Sweep Lower<br>Limit Reached Detect  |

**CF\_LLK\_IE Carrier Freq. Lock Lost Detect Interrupt Enable 10** The microcontroller sets CF\_LLK\_IE to enable an interrupt when Carrier Frequency Lock Loss is detected (CAR\_LCF=0). The L64704 always sets the CF\_LLK bit in STS[15:8] when this condition occurs.

#### CF\_LLK\_IE Definition

| 0 | Disable Interrupt for Carrier Frequency Lock<br>Loss Detect |
|---|-------------------------------------------------------------|
| 1 | Enable Interrupt for Carrier Frequency Lock Loss<br>Detect  |

**CF\_LK\_IE Carrier Frequency Lock Detect Interrupt Enable** 11 The microcontroller sets CF\_LK\_IE to enable an interrupt when Carrier Frequency Lock is detected (CAR\_LCF=1). The L64704 sets the CF\_LK bit in STS[15:8] when this condition occurs.

#### CF\_LK\_IE Definition

| 0 | Disable Carrier Frequency Lock Detect Interrupt |
|---|-------------------------------------------------|
| 1 | Enable Carrier Frequency Lock Detect Interrupt  |

**CP\_LLK\_IE Carrier Phase Lock Lost Detect Interrupt Enable 12** The microcontroller sets CP\_LLK\_IE to enable an interrupt when Carrier Phase Lock Loss is detected (CAR\_LC = 0). The L64704 always sets the CP\_LLK bit in STS[15:8] when this condition occurs.

#### CP\_LLK\_IE Definition

| 0 | Disable Interrupt for Carrier Phase Lock Loss<br>Detect |
|---|---------------------------------------------------------|
| 1 | Enable Interrupt for Carrier Phase Lock Loss Detect     |

**CP\_LK\_IE Carrier Phase Lock Detect Interrupt Enable** 13 The microcontroller sets CP\_LK\_IE to enable an interrupt when Carrier Phase Lock is detected (CAR\_LC = 1). The L64704 always sets the CP\_LK bit in STS[15:8] when this condition occurs.

#### CP\_LK\_IE Definition

| 0 | Disable Interrupt for Carrier Phase Lock Detect |
|---|-------------------------------------------------|
| 1 | Enable Interrupt for Carrier Phase Lock Detect  |

AFC\_LLK\_IE Clock AFC Lock Lost Detect Interrupt Enable 14 The microcontroller sets AFC\_LLK\_IE to enable an interrupt when Automatic Frequency Controller Lock Loss is detected. The L64704 always sets the AFC\_LLK bit in STS[15:8] when this condition occurs.

#### AFC\_LLK\_IE Definition

| 0 | Disable Interrupt for AFC Lock Lost Detect |
|---|--------------------------------------------|
| 1 | Enable Interrupt for AFC Lock Lost Detect  |

#### AFC\_LK\_IE Clock AFC Lock Detect Interrupt Enable 15 The microcontroller sets AFC\_LK\_IE to enable an interrupt when Automatic Frequency Controller Lock is detected. The L64704 always sets the AFC\_LK bit in STS[15:8] when this condition occurs.

| AFC_LK_IE | Definition                            |
|-----------|---------------------------------------|
| 0         | Disable Interrupt for AFC Lock Detect |
| 1         | Enable Interrupt for AFC Lock Detect  |

This register diagram shows the bit organization of SMR[7:0]. Descriptions of the fields follow the register diagram. The L64704 clears all bits in the SMR to zero after a software or hardware reset.

| APR | 7       | 6        | 5       | 4        | 3       | 2        | 1       | 0        |
|-----|---------|----------|---------|----------|---------|----------|---------|----------|
| 0   | VBER_IE | S3_LS_IE | S3_S_IE | S2_LS_IE | S2_S_IE | S1_LS_IE | S1_S_IE | Reserved |

VBER\_IE Viterbi Bit Error Rate Monitor Interrupt Enable 7 The microcontroller sets VBER\_IE to enable an interrupt when the Viterbi decoder reaches the period specified by VMDC2 (the period over which the Viterbi bit errors are counted). The L64704 always sets the VBER bit in STS[7:0] when this condition occurs.

#### VBER\_IE Definition

| 0 | Disable Interrupt for Viterbi BER Count |
|---|-----------------------------------------|
| 1 | Enable Interrupt for Viterbi BER Count  |

**S3\_LS\_IE** Stage 3 Loss of Synchronization Interrupt Enable 6 The microcontroller sets S3\_LS\_IE to enable an interrupt when Descrambler synchronization is lost.

| S3_LS_IE | Definition                                               |
|----------|----------------------------------------------------------|
| 0        | Disable Interrupt for Stage 3 Loss of<br>Synchronization |
| 1        | Enable Interrupt for Stage 3 Loss of<br>Synchronization  |

## S3\_S\_IEStage 3 Synchronization Interrupt Enable5The microcontroller sets S3\_S\_IE to enable an interrupt<br/>when Descrambler synchronization is established.

#### S3\_S\_IE Definition

| 0 | Disable Interrupt for Stage 3 Synchronization |
|---|-----------------------------------------------|
| 1 | Enable Interrupt for Stage 3 Synchronization  |

S2\_LS\_IE Stage 2 Loss of Synchronization Interrupt Enable 4 The microcontroller sets S2\_LS\_IE to enable an interrupt when Deinterleaver/Reed-Solomon Decoder synchronization is lost.

#### S2\_LS\_IE Definition

| 0 | Disable Interrupt for Stage 2 Loss of |  |
|---|---------------------------------------|--|
|   | Synchronization                       |  |
| 1 | Enable Interrupt for Stage 2 Loss of  |  |
|   | Synchronization                       |  |
|   |                                       |  |

S2\_S\_IE Stage 2 Synchronization Interrupt Enable 3 The microcontroller sets S2\_S\_IE to enable an interrupt when Deinterleaver/Reed-Solomon Decoder synchronization is established.

| S2_S_IE | Definition                     |
|---------|--------------------------------|
| 0       | Diachla Staga 2 Synahranizatia |

| 0 | Disable Stage 2 Synchronization Interrupt |
|---|-------------------------------------------|
| 1 | Enable Stage 2 Synchronization Interrupt  |
|   |                                           |

S1\_LS\_IE Stage 1 Loss of Synchronization Interrupt Enable 2 The microcontroller sets S1\_LS\_IE to enable an interrupt when Viterbi Decoder synchronization is lost.

| S1_LS_IE | Definition                                           |
|----------|------------------------------------------------------|
| 0        | Disable Stage 1 Loss of Synchronization<br>Interrupt |
| 1        | Enable Stage 1 Loss of Synchronization Interrupt     |

 S1\_S\_IE
 Stage 1 Synchronization Interrupt Enable
 1

 The microcontroller sets S1\_S\_IE to enable an interrupt when Viterbi Decoder synchronization is established.
 1

| S1_S_IE | Definition                                |
|---------|-------------------------------------------|
| 0       | Disable Stage 1 Synchronization Interrupt |
| 1       | Enable Stage 1 Synchronization Interrupt  |

| Reserved | Reserved Bit                                          | 0   |
|----------|-------------------------------------------------------|-----|
|          | This bit is reserved for LSI Logic internal use only. | You |
|          | should always set this bit to 0.                      |     |

3.4.2 The STS Register is a read-only register that provides the external microcontroller access to status information about the L64704. It provides information about what event caused the generation of an internal interrupt condition. The interrupt status bits are set regardless of the enable interrupt bits in the SMR Register. The internal status is updated every L64704 OCLK. When the microcontroller reads the status, the current information is buffered in a special purpose 16-bit STS buffer that locks the STS value until the end of the microcontroller read operation.

Two consecutive read operations must be done to the same address to get both bytes of the STS. The eight MSBs are the interrupts related to the Demodulation function of the L64704, and the eight LSBs are the interrupts related to the Forward Error Correction function of the L64704.

The status bits are reset after a hardware reset. They are also reset each time that the register byte is read; when you read the eight LSBs, the eight LSB interrupts are cleared, and when you read the eight MSBs, the eight MSB interrupts are cleared. The register diagram below shows a detailed description of the STS[15:8] register bits:

| APR | D15   | D14   | D13    | D12                                                                                               | D11        | D10   | D9                           | D8          |
|-----|-------|-------|--------|---------------------------------------------------------------------------------------------------|------------|-------|------------------------------|-------------|
| 1   | FS_UL | FS_LL | CF_LLK | CF_LK                                                                                             | CP_LLK     | CP_LK | AFC_LLK                      | AFC_LK      |
|     |       | FS_UL | The    | L64704 s                                                                                          |            |       | eached<br>upper limit        | 0<br>of the |
|     |       |       | FS_    | FS_UL Definition                                                                                  |            |       |                              |             |
|     |       |       | 0<br>1 | <ol> <li>Frequency Sweep Status Unchanged</li> <li>Frequency Sweep Upper Limit Reached</li> </ol> |            |       |                              |             |
|     |       | FS_LL | The    | L64704 s                                                                                          | •          |       | eached<br>Iower limit d      | 1<br>of the |
|     |       |       | FS_    |                                                                                                   | Definition |       |                              |             |
|     |       |       | 0<br>1 |                                                                                                   |            | •     | s Unchangeo<br>r Limit React |             |
|     |       |       |        |                                                                                                   |            |       |                              |             |

| CF_LLK  | Carrier Frequency Lock Lost2The L64704 sets this bit when Carrier Frequency Lock islost.                   |                                                                               |  |  |  |  |  |
|---------|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--|--|--|--|--|
|         | CF_LLK                                                                                                     | Definition                                                                    |  |  |  |  |  |
|         | 0<br>1                                                                                                     | Carrier Frequency Lock Status Unchanged<br>Carrier Frequency Lock Lost        |  |  |  |  |  |
| CF_LK   | Carrier Frequency Lock Established3The L64704 sets this bit when Carrier Frequency Lock is<br>established. |                                                                               |  |  |  |  |  |
|         | CF_LK                                                                                                      | Definition                                                                    |  |  |  |  |  |
|         | 0<br>1                                                                                                     | Carrier Frequency Lock Status Unchanged<br>Carrier Frequency Lock Established |  |  |  |  |  |
| CP_LLK  |                                                                                                            | <b>se Lock Lost 4</b><br>sets this bit when Carrier Phase Lock is lost.       |  |  |  |  |  |
|         | CP_LLK                                                                                                     | Definition                                                                    |  |  |  |  |  |
|         | 0<br>1                                                                                                     | Carrier Phase Lock Status Unchanged<br>Carrier Phase Lock Lost                |  |  |  |  |  |
| CP_LK   | Carrier Phase Lock Established5The L64704 sets this bit when Carrier Phase Lock is<br>established.5        |                                                                               |  |  |  |  |  |
|         | CP_LK                                                                                                      | Definition                                                                    |  |  |  |  |  |
|         | 0<br>1                                                                                                     | Carrier Phase Lock Status Unchanged<br>Carrier Phase Lock Established         |  |  |  |  |  |
| AFC_LLK | Clock AFC<br>The L64704                                                                                    | Lock Lost14sets this bit when Clock AFC Lock is lost.                         |  |  |  |  |  |
|         | AFC_LLK                                                                                                    | Definition                                                                    |  |  |  |  |  |
|         | 0<br>1                                                                                                     | Clock AFC Lock Status Unchanged<br>Clock AFC Lock Lost                        |  |  |  |  |  |
| AFC_LK  |                                                                                                            | Lock Established15sets this bit when Clock AFC Lock is                        |  |  |  |  |  |
|         | AFC_LK                                                                                                     | Definition                                                                    |  |  |  |  |  |
|         | 0<br>1                                                                                                     | Clock AFC Lock Status Unchanged<br>Clock AFC Lock Established                 |  |  |  |  |  |

The register diagram below shows a detailed description of the STS[7:0] register bits.

| APR                                                                                                                                                                              | 7    | 6      | 5                                     | 4                                                                                                                                                                                                                                                                                                   | 3      | 2                            | 1           | 0        |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------|-------------|----------|--|--|
| 0                                                                                                                                                                                | VBER | S3_LS  | \$3_\$                                | S2_LS                                                                                                                                                                                                                                                                                               | S2_S   | S1_LS                        | S1_S        | Reserved |  |  |
|                                                                                                                                                                                  |      | VBER   | The<br>VMD<br>gene<br>set.<br>Grou    | Viterbi Bit Error Rate Flag<br>The L64704 sets VBER when the period specified by<br>VMDC2 (Group 4, APRs 5, 6, and 7) is reached. It a<br>generates an interrupt if the VBER_IE bit in the SMR<br>set. The L64704 clears VBER to zero after a reset o<br>Group 2 (STS) read.                        |        |                              |             |          |  |  |
|                                                                                                                                                                                  |      |        |                                       |                                                                                                                                                                                                                                                                                                     |        | ad uset Desek                |             |          |  |  |
|                                                                                                                                                                                  |      |        | 0<br>1                                |                                                                                                                                                                                                                                                                                                     |        | od not Reach<br>od Reached   |             |          |  |  |
|                                                                                                                                                                                  |      | S3_LS  | The<br>nizat<br>also<br>the S<br>or a | Stage 3 Loss of Synchronization Flag<br>The L64704 sets S3_LS when the Descrambler synchronization module determines that synchronization is lost.<br>also generates an interrupt if the S3_LS_IE bit is set i<br>the SMR. The L64704 clears S3_LS to zero after a rese<br>or a Group 2 (STS) read. |        |                              |             |          |  |  |
|                                                                                                                                                                                  |      |        | <b>S3</b> _ <br>0                     |                                                                                                                                                                                                                                                                                                     |        |                              |             |          |  |  |
|                                                                                                                                                                                  |      |        | 0<br>1                                |                                                                                                                                                                                                                                                                                                     |        | chronization<br>e 3 Synchror |             | -        |  |  |
|                                                                                                                                                                                  |      | \$3_\$ | The<br>nizat<br>ates<br>L647          | Stage 3 Synchronization Flag<br>The L64704 sets S3_S when the Descrambler synch<br>nization module acquires synchronization. It also gen<br>ates an interrupt if the S3_S_IE bit is set in the SMR. T<br>L64704 clears S3_S to zero after a reset or a Group<br>(STS) read.                         |        |                              |             |          |  |  |
|                                                                                                                                                                                  |      |        | S3_                                   | S3_S Definition                                                                                                                                                                                                                                                                                     |        |                              |             |          |  |  |
|                                                                                                                                                                                  |      |        | 0<br>1                                | Status Unc<br>Acquired                                                                                                                                                                                                                                                                              | hanged |                              |             |          |  |  |
| S2_LS Stage 2 Loss of Synchronization Flag<br>The L64704 sets S2_LS when the Deinter<br>Solomon Decoder synchronization module<br>that synchronization is lost. It also generate |      |        |                                       |                                                                                                                                                                                                                                                                                                     |        |                              | Deinterleav | ermines  |  |  |

if the S2\_LS\_IE bit is set in the SMR. The L64704 clears S2\_LS to zero after a reset or a Group 2 (STS) read.

#### S2\_LS Definition

| 0 | Stage 2 Synchronization Status Unchanged |
|---|------------------------------------------|
| 1 | Loss of Stage 2 Synchronization Detected |

| S2_S | Stage 2   | Synchronization Flag                           | 3 |
|------|-----------|------------------------------------------------|---|
|      | The L647  | 704 sets S2_S when the Deinterleaver/Reed-     |   |
|      | Solomon   | Decoder synchronization module acquires        |   |
|      | synchron  | ization. It also generates an interrupt if the |   |
|      | S2_S_IE   | bit is set in the SMR. The L64704 clears S2_S  |   |
|      | to zero a | fter a reset or a Group 2 (STS) read.          |   |
|      | S2_S      | Definition                                     |   |

| 0 | Stage 2 Synchronization Status Unchanged |
|---|------------------------------------------|
| 1 | Stage 2 Synchronization Acquired         |

S1\_LSStage 1 Loss of Synchronization Flag2The L64704 sets S1\_LS when the Viterbi Decoder<br/>synchronization module determines that synchronization<br/>is lost. It also generates an interrupt if the S1\_LS\_IE bit<br/>is set in the SMR. The L64704 clears S1\_LS to zero after<br/>a reset or a Group 2 (STS) read.

| S1_LS | Definition                               |
|-------|------------------------------------------|
| 0     | Stage 1 Synchronization Status Unchanged |
| 1     | Loss of Stage 1 Synchronization Detected |

# S1\_S Stage 1 Synchronization Flag 1 The L64704 sets S1\_S when the Viterbi Decoder synchronization module has acquired synchronization. It also generates an interrupt if the S1\_S\_IE bit is set in the SMR. The L64704 clears S1\_S to zero after a reset or a Group 2 (STS) read. 1 S1\_S Definition 0 Stage 1 Synchronization Status Unchanged 1 Stage 1 Synchronization Acquired

#### Reserved Reserved Bit 0 This bit is reserved for LSI Logic internal use only. Read

ing this bit will give unpredictable results.

3.5 Group 3 consists of a number of internal status registers that are used for diagnostics and performance evaluation purposes. The registers are updated every OCLK cycle. When the microcontroller reads the register, the current information is buffered in a special purpose buffer that stores the value of the respective register until the end of the read operation. The L64704 clears all the bits in the Group 3 registers to zero after a software or a hardware reset.

Table 3.3 shows the addresses and fields of the Group 3 registers.

| Table 3.3        |     |
|------------------|-----|
| Group 3 Register | Мар |

| APR | D7                                                                                   | D6     | D5          | D4            | D3           | D2           | D1      | D0  |  |  |
|-----|--------------------------------------------------------------------------------------|--------|-------------|---------------|--------------|--------------|---------|-----|--|--|
| 0   | Reed-Solomon Corrected Error Count Low Byte, CEC[7:0]                                |        |             |               |              |              |         |     |  |  |
| 1   |                                                                                      | Reed-  | Solomon Co  | prrected Erro | or Count Hig | h Byte, CEC  | [15:8]  |     |  |  |
| 2   |                                                                                      | Reed-  | Solomon Un  | corrected E   | rror Count L | ow Byte, UE  | C[7:0]  |     |  |  |
| 3   |                                                                                      | Reed-S | Solomon Und | corrected Er  | ror Count Hi | gh Byte, UE  | C[15:0] |     |  |  |
| 4   | Viterbi Bit Error Rate Count Low Byte, VBERC[7:0]                                    |        |             |               |              |              |         |     |  |  |
| 5   | Viterbi Bit Error Rate Count High Byte, VBERC[15:8]                                  |        |             |               |              |              |         |     |  |  |
| 6   | Demod_<br>SNR         XCTR_IN         Measured Carrier VCO Frequency, CAR_VCOF[13:8] |        |             |               |              |              |         | :8] |  |  |
| 7   |                                                                                      | M      | easured Ca  | rrier VCO Fr  | equency, CA  | R_VCOF[7:    | 0]      |     |  |  |
| 8   | AGC Loop Voltage Meter, PWR_LVL[7:0]                                                 |        |             |               |              |              |         |     |  |  |
| 9   | Rese                                                                                 | erved  | CAR_LCF     | CAR_LC        | CLK_LCF      | S3           | S2      | S1  |  |  |
| 10  | Rese                                                                                 | erved  |             |               | RI Readba    | ick, RI[5:0] |         |     |  |  |
| 11  | Rese                                                                                 | erved  |             |               | RQ Readba    | ick, RQ[5:0] |         |     |  |  |

3.5.1 When read, this register presents a count of corrected errors since it was last reset. When written, the register is reset to zero. CEC is 16-bits long, where the LSB is found on APR 0, bit 0, and the MSB on APR 1, bit 7. The CEC counter is incremented each time that a byte is corrected, independent of the number of bit errors that are encountered in the byte. It is not incremented when a block is flagged as uncorrectable. The CEC counter will wrap around when it reaches its maximum count.



# **3.5.2**When read, this register presents a count of the uncorrected code words**Group 3,**since it was last reset. When written, the register is set to zero. UEC is**APR 2, 3**16 bits long, where the LSB is found on APR 2, bit 0, and the MSB on**RS Uncorrected**APR 3, bit 7. The UEC count stops when it reaches its maximum count**Error Count**(65535), and the counter is reset each time that it is read.

#### Read/Write: R/W

#### Reset Value: 0x0000



3.5.3 When read, this register presents a count of the number of Viterbi decoder bit errors found during the time period specified by VMDC2
APR 4, 5 (Group 4, APR [5:5]). VBERC is 16-bits long, where the LSB is found on APR 4, bit 0, and the MSB on APR 5, bit 7. The actual number of errors is equal to four times VBERC. VBERC is updated each time that a Viterbi error is encountered, and it is reset at the beginning of each VMDC2 period.

#### Read/Write: R Reset Value: 0x0000 APR D7 D6 D5 D4 D3 D2 D1 D0 4 Viterbi Bit Error Rate Count Low Byte, VBERC[7:0] APR D7 D6 D5 D4 D3 D2 D1 D0 5 Viterbi Bit Error Rate Count High Byte, VBERC[15:8]

# **3.5.4**This register contains the Control Input bit(s), the Demodulator SNR bit,<br/>and the five upper bits of the Measured VCO Frequency. The Control<br/>Input bit(s) and the Demodulator SNR bit are discussed here, the<br/>Measured VCO Frequency field CAR\_VCOF[13:8], is discussed in the<br/>next section.

#### Read/Write: R/W

#### Reset Value: 0x0000

| APR | D7            | D6      | D5 | D4 | D3     | D2       | D1 | D0 |
|-----|---------------|---------|----|----|--------|----------|----|----|
| 6   | Demod<br>_SNR | XCTR_IN |    |    | CAR_VC | OF[13:8] |    |    |

| Demod_SNR | Demodulator Signal to Noise Ratio7When read, this bit gives an indication of the SNR. When<br>the SNR is bad, this bit is 0; when it is good, this bit is 1.<br>A "bad" SNR is above the threshold; a "good" SNR is<br>below the threshold. See Section 5.6.2.1, "Phase Error<br>Estimator," and Figure 5.7 for details. |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XCTR_IN   | External Control Input Bit 6                                                                                                                                                                                                                                                                                             |

When read, this bit shows the logic level applied to the External Control Input (XCTR\_IN) pin.

3.5.5 The L64704 puts the result of the VCO frequency measurement into this Group 3, 16-bit register. Both the upper and lower nibbles must be read before the APR 6.7 L64704 releases this register for a new value. See Section 5.6.1.2, Measured VCO "Carrier VCO Frequency Measurement," for details on how the L64704 Frequency computes this value.

#### Read/Write: R

3.5.7

APR 9

Status

Group 3,

Reset Value: 0x0000

| APR | D7            | D6      | D5             | D4    | D3       | D2 | D1 | D0 |  |
|-----|---------------|---------|----------------|-------|----------|----|----|----|--|
| 6   | Demod<br>_SNR | XCTR_IN | CAR_VCOF[13:8] |       |          |    |    |    |  |
| APR | D7            | D6      | D5             | D4    | D3       | D2 | D1 | D0 |  |
| 7   |               |         |                | CAR_V | COF[7:0] |    |    |    |  |

| 3.5.6<br>Group 3,<br>APR 8 | The L64704 stores the AGC loop control voltage in this register. See Section 5.7.3, "Power Level," for an equation that relates $V_{AGC}$ and PWR_LVL. |              |    |    |    |    |    |                   |    |  |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----|----|----|----|----|-------------------|----|--|
| AGC Loop<br>Voltage Meter  | Read/                                                                                                                                                  | _            |    |    |    |    |    | Reset Value: 0x00 |    |  |
|                            | APR _                                                                                                                                                  | D7           | D6 | D5 | D4 | D3 | D2 | D1                | D0 |  |
|                            | 8                                                                                                                                                      | PWR_LVL[7:0] |    |    |    |    |    |                   |    |  |

This register contains the Carrier Loop and FEC pipeline synchronization status bits.

Read/Write: R Reset Value: 0x00 **Carrier and FEC** Synchronization APR D7 D6 D5 D4 D3 D2 D1 D0 CAR\_ CAR\_LC CLK\_LCF Reserved S3 S2 S1 9 LCF Reserved Reserved Bits [7:6] These bits are reserved for LSI Logic internal use only. When read, they will return an indeterminate value.

| CAR_LCF | The L64704                                                                                           | Carrier Frequency Lock Flag<br>The L64704 sets CAR_LCF to 1 to indicate that the<br>carrier frequency lock detector is in lock.                       |  |  |  |  |  |  |
|---------|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|         | CAR_LCF                                                                                              | Definition                                                                                                                                            |  |  |  |  |  |  |
|         | 0<br>1                                                                                               | Carrier Frequency Lock Detector Out of Lock<br>Carrier Frequency Lock Detector Locked                                                                 |  |  |  |  |  |  |
| CAR_LC  | The L64704                                                                                           | set SCAR_LC to 1 to indicate that the carrier detector is locked.                                                                                     |  |  |  |  |  |  |
|         | CAR_LC                                                                                               | Definition                                                                                                                                            |  |  |  |  |  |  |
|         | <ul><li>Carrier Phase Lock Detector Out of Lock</li><li>Carrier Phase Lock Detector Locked</li></ul> |                                                                                                                                                       |  |  |  |  |  |  |
| CLK_LCF | The L64704                                                                                           | sets CLK_LCF to 1 to indicate that the clock<br>the AFC control is within pull-in range of the<br>ery loop.                                           |  |  |  |  |  |  |
|         | CLK_LCF                                                                                              | Definition                                                                                                                                            |  |  |  |  |  |  |
|         | 0<br>1                                                                                               | Clock Frequency Out of Lock<br>Clock Frequency Locked                                                                                                 |  |  |  |  |  |  |
| S3      | The L64704 nization mod                                                                              | nchronization Flag2sets S3 to 1 when the Descrambler synchro-<br>dule is in synchronization. When this bit is 0,<br>hbler module is not synchronized. |  |  |  |  |  |  |
|         | S3                                                                                                   | Definition                                                                                                                                            |  |  |  |  |  |  |
|         | 0<br>1                                                                                               | Descrambler Out of Synchronization<br>Descrambler In Synchronization                                                                                  |  |  |  |  |  |  |

3-24

| S2 | The L64704<br>Solomon De<br>nization. Wh                   | achronization Flag1sets S2 to 1 when the Deinterleaver/Reed-coder synchronization module is in synchro-en this bit is 0, the Deinterleaver/Reed-coder is not synchronized. |  |  |  |  |  |
|----|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|    | S2 Definition                                              |                                                                                                                                                                            |  |  |  |  |  |
|    | 0                                                          | Deinterleaver/Reed-Solomon Decoder<br>Out of Synchronization                                                                                                               |  |  |  |  |  |
|    | 1 Deinterleaver/Reed-Solomon Decoder<br>In Synchronization |                                                                                                                                                                            |  |  |  |  |  |
| S1 | The L64704 synchronizat                                    | achronization Flag0sets S1 to 1 when the Viterbi Decoderion module is in synchronization. When thisViterbi Decoder is not synchronized.                                    |  |  |  |  |  |
|    | S1                                                         | Definition                                                                                                                                                                 |  |  |  |  |  |
|    | 0<br>1                                                     | Viterbi Decoder Out of Synchronization<br>Viterbi Decoder In Synchronization                                                                                               |  |  |  |  |  |
|    |                                                            |                                                                                                                                                                            |  |  |  |  |  |

| 3.5.8                 | This register displays the value on the RI[ | 5:0] input bus. Group 3, RI |
|-----------------------|---------------------------------------------|-----------------------------|
| Group 3,              | values are only correct when the PLL is s   | et such that ICLK = OCLK.   |
| APR 10<br>RI Readback | Read/Write: R                               | Reset Value: 0x00           |

| APR | D7   | D6    | D5 | D4 | D3 | D2 | D1 | D0 |
|-----|------|-------|----|----|----|----|----|----|
| 10  | Rese | erved |    |    | R  | RI |    |    |

### ReservedReserved Bits[7:6]These bits are reserved for LSI Logic internal use only.<br/>When read, they will return an indeterminate value.

| RI | <b>RI Readback</b> [5] This register displays the value on the RI[5:0] input bu | 5:0] |
|----|---------------------------------------------------------------------------------|------|
|    | (Note that OCLK needs to be running for this feature operate properly).         |      |

| 3.5.9<br>Group 3,<br>APR 11 | This register displays the value on the RQ values are only correct when the PLL is se |                   |
|-----------------------------|---------------------------------------------------------------------------------------|-------------------|
| RQ Readback                 | Read/Write: R                                                                         | Reset Value: 0x00 |

| APR                                                                                                                                    | D7   | D6                 | D5 | D4                    | D3                      | D2 | D1 | D0 |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------|------|--------------------|----|-----------------------|-------------------------|----|----|----|--|--|
| 11                                                                                                                                     | Rese | Reserved           |    | red RQ                |                         |    |    |    |  |  |
| ReservedReserved Bits[7:These bits are reserved for LSI Logic internal use only<br>When read, they will return an indeterminate value. |      |                    |    |                       |                         |    | •  |    |  |  |
| RQ                                                                                                                                     |      | This re<br>(Note t | •  | splays th<br>_K needs | e value o<br>s to be ru |    |    |    |  |  |

3.6 Most Group 4 registers are 8 bits wide while some registers are wider
 Group 4 (up to 24 bits). All accesses are done in 8-bit widths. The Address
 Pointer Register (APR) is used to access these registers as described in Section 3.3, "Group 0, 1 Address Pointer Register."

Group 4 registers are not affected by a reset. Group 4 registers appear random immediately after power-up, and retain their last known value after any of the three reset operations as shown in 3.2, "Reset and How It Affects Registers." Table 3.4 shows the addresses and fields of the Group 4 registers.

Table 3.4 Group 4 Register Map

| APR[5:0] | D7               | D6                         | D5              | D4                  | D3                   | D2              | D1            | DO                  |  |  |
|----------|------------------|----------------------------|-----------------|---------------------|----------------------|-----------------|---------------|---------------------|--|--|
| 0        | Set to 1         | Set to 0                   |                 |                     | PLL_N                | PLL_N[5:0]      |               |                     |  |  |
| 1        | Set to 0         | Set to 0                   | PLL_S[5:0]      |                     |                      |                 |               |                     |  |  |
| 2        | IMQ              | IMQ Set to 1 QB PLL_T[4:0] |                 |                     |                      |                 |               |                     |  |  |
| 3        | Viterbi (        | Code Rate, V               | CR[2:0]         | TEI                 | SYNC2_MOD            | Set to 0        | PLL_I         | M[1:0]              |  |  |
| 4        |                  |                            | Viterbi         | Max Data Bi         | t Count, VMDC        | ;1[7:0]         |               |                     |  |  |
| 5        |                  |                            |                 |                     | nt 2, VMDC2[7:       |                 |               |                     |  |  |
| 6        |                  |                            |                 |                     | 2, VMDC2[15:8        |                 |               |                     |  |  |
| 7        |                  | Vi                         |                 |                     | 2, VMDC2[23:         |                 | 9             |                     |  |  |
| 8        |                  |                            |                 |                     | rror Count, VM       |                 |               |                     |  |  |
| 9        |                  |                            | Sy              | nchronization       | Word, Sync[7:        | 0]              |               |                     |  |  |
| 10       | BER              |                            |                 | Reserved            |                      |                 | L[1           |                     |  |  |
| 11       | BF               | Set to 0                   |                 | us Select,<br>[1:0] | Sync Stat<br>SSA     |                 |               | tes Track,<br>[1:0] |  |  |
| 12       |                  | BPS[2:0]                   |                 | Set to 0            | OF                   | Outpu           | t Selector, O | S[2:0]              |  |  |
| 13       |                  |                            |                 | PLL_                | RESET                |                 |               |                     |  |  |
| 14       | SYNC/<br>SCLK    | Reserved                   | Set to 0        | F_OUT_<br>HiZ       | CLK_LCF_<br>SUPPRESS | CLK_VC_<br>SWAP | CLK_E         | DR[1:0]             |  |  |
| 15       | Set to 0         | PCLK_BP                    | Set to 0        | PD                  |                      | CLK_RF          | P[3:0]        |                     |  |  |
| 16       |                  | CLK_NF[15:8]               |                 |                     |                      |                 |               |                     |  |  |
| 17       |                  |                            |                 | CLK_                | NF[7:0]              |                 |               |                     |  |  |
| 18       |                  |                            | Reserved        |                     |                      | CL              | K_RATIO[2:    | 0]                  |  |  |
| 19       |                  |                            |                 | PWR_I               | REF[7:0]             |                 | -             |                     |  |  |
| 20       |                  |                            | Reserved        |                     |                      | INT_DC          | PWR_E         | BW[1:0]             |  |  |
| 21       |                  |                            |                 |                     | II, DEMQ, SCA        | <u> </u>        |               |                     |  |  |
| 22       |                  |                            | SNR Est         | imator Thre         | shold, SNR_1         | FHS[7:0]        |               |                     |  |  |
| 23       |                  | Carrie                     | r Loop DC       | Offset Com          | pensation, CA        | AR_OFFSE1       | [7:0]         |                     |  |  |
| 24       |                  | Rese                       | rved            |                     | Carrier I            | Reference Pe    | riod, CAR_R   | P[3:0]              |  |  |
| 25       |                  |                            | Carrier Loo     | op Filter Gair      | n (P Term), CAI      | R_KP[7:0]       |               |                     |  |  |
| 26       |                  |                            | Carrier Loo     | op Filter Gair      | n (D Term), CAI      | R_KD[7:0]       |               |                     |  |  |
| 27       |                  |                            | Carrier Loc     | k Detector T        | hreshold, CAR_       | THSL[7:0]       |               |                     |  |  |
| 28       |                  |                            | Carri           | er Sweep Ra         | ate, CAR_SWR         | [7:0]           |               |                     |  |  |
| 29       | Rese             | erved                      |                 | Carrier U           | lpper Sweep Li       | mit, CAR_US     | WL[13:8]      |                     |  |  |
| 30       |                  |                            | Carrier U       | pper Sweep          | Limit, CAR_US        | SWL[7:0]        |               |                     |  |  |
| 31       | Rese             | erved                      |                 |                     | ower Sweep Li        |                 | WL[13:8]      |                     |  |  |
| 32       |                  |                            |                 | · · ·               | Limit, CAR_LS        |                 |               |                     |  |  |
| 33       | CAR_SWP_<br>SWAP | CAR_VCO_<br>SWAP           | CAR_VCO<br>2N/P | CAR_VCO<br>1N/P     | CAR_OUT_S<br>EL      | CAR_PED_<br>SEL | CAR_<br>OPEN  | CAR_SW              |  |  |
| 34       |                  | Set to 0                   |                 |                     |                      | Reserved        |               |                     |  |  |
| 35       | SNR_EST          | CON_SEL                    | Set to 0        | FP_LOCK_<br>LEN     | PWRP                 | Set             | to 0          | I_FORMAT            |  |  |
| 36       | Rese             | erved                      | Exter           | nal Control C       | output Bits, XC1     | R[3:0]          | DEMOD_<br>RST | FEC_<br>RST         |  |  |

3.6.1 PLL Configuration Parameter N is used to configure the PLL module forGroup 4, clock synthesis.APR 0 PLL

Parameter N

Read/Write: R/W

| APR   | D7       | D6                                                                                                                                                                                                                                                | D5                                                                | D4 | D3 | D2 | D1 | D0 |  |  |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|----|----|----|----|----|--|--|
| 0     | Set to 1 | Set to 0                                                                                                                                                                                                                                          | PLL_N[5:0]                                                        |    |    |    |    |    |  |  |
| Set t | o 1      |                                                                                                                                                                                                                                                   | Set to 17LSI Logic internal test bit. You must set this bit to 1. |    |    |    |    |    |  |  |
| Set t | io 0     | <b>Set to 0</b><br>LSI Logic internal test bit. You must set this bit to 0.                                                                                                                                                                       |                                                                   |    |    |    |    |    |  |  |
| PLL_  | _N       | PLL Configuration Parameter N [5:0<br>PLL_N[5:0] is one of four parameters (PLL_S, PLL_N,<br>PLL_T, PLL_M) that you must set to configure the PLL<br>module for clock synthesis. For more information see<br>Section 4.4, "PLL Clock Generation." |                                                                   |    |    |    |    |    |  |  |

**3.6.2** PLL Configuration Parameter S is used to configure the PLL module for **Group 4**, clock synthesis.

#### APR 1 PLL Parameter S

Read/Write: R/W



Section 4.4, "PLL Clock Generation."

PLL Configuration Parameter T is used to configure the PLL module for clock synthesis. This register also contains bits to configure the demodulator and select the symbol format.

#### Read/Write: R/W

| APR    | D7                                                                                                                                                                                                      | D6                                                                                                                              | D5                             | D4                      | D3                                   | D2                                              | D1                   | D0                   |  |  |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-------------------------|--------------------------------------|-------------------------------------------------|----------------------|----------------------|--|--|
| 2      | IMQ                                                                                                                                                                                                     | Set to 1                                                                                                                        | QB                             |                         | PLL_T[4:0]                           |                                                 |                      |                      |  |  |
| IMQ    |                                                                                                                                                                                                         | (I, -Q) Symbol Format<br>The bit IMQ indicates the format of the incoming syn<br>stream. In BPSK mode, IMQ must be set to zero. |                                |                         |                                      |                                                 |                      |                      |  |  |
|        |                                                                                                                                                                                                         | 0<br>1                                                                                                                          | I, Q<br>I, -(                  |                         |                                      |                                                 |                      |                      |  |  |
| Set to | o 1                                                                                                                                                                                                     | Set to 1 6<br>This bit must be set to 1 for proper operation.                                                                   |                                |                         |                                      |                                                 |                      |                      |  |  |
| QB     |                                                                                                                                                                                                         | Set the<br>bol stre<br>input a                                                                                                  | e QB bit<br>eam. The<br>QPSK s | e QB bit s<br>symbol pa | y the for<br>should be<br>air (I, Q) | mat of th<br>e set to 0<br>once per<br>PSK inpu | for syste<br>ICLK cy | ems that<br>cle. The |  |  |
|        |                                                                                                                                                                                                         | QB                                                                                                                              | Symbol                         | Stream F                | ormat                                |                                                 |                      |                      |  |  |
|        |                                                                                                                                                                                                         | 0 QPSK<br>1 BPSK                                                                                                                |                                |                         |                                      |                                                 |                      |                      |  |  |
| PLL_   | _T PLL Configuration Parameter T [<br>PLL_T[4:0] is one of four parameters (PLL_S, PLL_N<br>PLL_T, PLL_M) that you must set to configure the PL<br>module for clock synthesis. For more information see |                                                                                                                                 |                                |                         |                                      |                                                 |                      |                      |  |  |

Section 4.4, "PLL Clock Generation."

Group 4, APR 2 PLL Parameter T, Demodulator and Symbol Select

3.6.3

3.6.4 Group 4, APR 3 PLL Parameter M, Transport and Viterbi Code Rate Select PLL Configuration Parameter M is used to configure the PLL module for clock synthesis. This register also contains bits to set the Viterbi Decoder module code rate and configure the Transport Error Indicator.

#### Read/Write: R/W

| APR                                                                                                                                                            | D7         | D6    |             | D5   | 5    | D4       | D3            | D2       | D1                      | D0     |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------|-------------|------|------|----------|---------------|----------|-------------------------|--------|
| 3                                                                                                                                                              | Viterbi Co | de Ra | ite, V      | CR[2 | :0]  | TEI      | SYNC2_<br>MOD | Set to 0 | PLL_N                   | 1[1:0] |
| VCR[2:0] Viterbi Code Rate<br>Set these bits to SELECT the code rate for the Viter<br>decoder module on the L64704. The three bits are<br>assigned as follows: |            |       |             |      |      |          |               |          |                         |        |
|                                                                                                                                                                |            |       | ta Bi<br>D6 |      | Defi | inition  |               |          |                         |        |
|                                                                                                                                                                |            | 0     | 0           | 0    | Rate | e 1/2    | -             |          |                         |        |
|                                                                                                                                                                |            | 0     | 0           | 1    |      | e 2/3    |               |          |                         |        |
|                                                                                                                                                                |            | 0     | 1           | 0    |      | e 3/4    |               |          |                         |        |
|                                                                                                                                                                |            | 0     | 1           | 1    |      | e 5/6    |               |          |                         |        |
|                                                                                                                                                                |            | 1     | 0           | 0    |      | e 7/8    |               |          |                         |        |
|                                                                                                                                                                |            | 1     | 0           | 1    | Unu  |          |               |          |                         |        |
|                                                                                                                                                                |            | 1     | 1           | 0    | Unu  |          |               |          |                         |        |
|                                                                                                                                                                |            | 1     | 1           | 1    | Unu  | sed      | _             |          |                         |        |
| TEI                                                                                                                                                            |            | You   | set         | the  | Trar | nsport I |               | cator Se | lect bit to<br>chanism. |        |

You set the Transport Error Indicator Select bit to 1 to activate the transport error indicator mechanism. In this mode, the first bit following the synchronization byte in a Transport Packet is forced HIGH whenever the data block was found to be uncorrectable by the Reed-Solomon decoder. Otherwise it remains unchanged. When TEI is set to 0, the transport error indicator will not be set at any time. (See the MPEG-2 System Specification H.222, paragraph 2.4.3.2 Transport Stream Packet Layer.) Using the TEI feature allows a simpler interface to the LSI Logic L64007 Transport Demultiplexer. For more information, see LSI Logic *L64007 MPEG-2, DVB, and TSAT Transport Demultiplexer Technical Manual.* 

| SYNC2_MOD | This                                | bit s                                                    | Iodified3elects an alternate method of acquiring Sync 2.be set to 1 for normal operation.                                                                                                                                                                                |  |  |  |  |  |  |  |
|-----------|-------------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Set to 0  |                                     | Set to 02This bit must be set to 0 for proper operation. |                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| PLL_M     | PLL<br>PLL<br>for c<br>"PLL<br>L647 | _M is<br>_M) f<br>lock =<br>Clo<br>704 t<br>a Bits       | equency Range for PLL Module [1:0]<br>sone of four parameters (PLL_S, PLL_N, PLL_T,<br>that you must set to configure the PLL module<br>synthesis. For more information see Section 4.4,<br>ck Generation." Set PLL_M[1:0] to tell the<br>he frequency range of the VCO. |  |  |  |  |  |  |  |
|           | 0                                   | 0                                                        | 40 - 50 MHz                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |

| 0 | 0 | 40 - 50 MHz |
|---|---|-------------|
| 0 | 1 | 50 - 60 MHz |
| 1 | 0 | 60 - 70 MHz |
| 1 | 1 | 70 - 80 MHz |

**3.6.5**VMDC1 specifies the number of valid symbols, divided by 256, over**Group 4,**which the number of Viterbi decoded symbol errors are counted for<br/>synchronization. For example, a value of VMDC1[7:0] = 0b0000001**Viterbi Max Data**Bit Count 1Bit Count 1Bit Error Rate Monitor."

#### Read/Write: R/W



3.6.6 Group 4, APR 5, 6, 7 Viterbi Max Data Bit Count 2

VMDC2 specifies the number of valid symbols, divided by 4, over which the number of symbol errors in the Viterbi output data stream are counted, after synchronization. The symbol error count is then displayed as VBERC (Group 3, APR 4:5). The value for VMDC2 occupies 24 bits and is arranged as three bytes with APR 5, bit 0 being the least significant bit and APR 7, bit 7 being the most significant bit. For example, a value of VMDC2[23:0] = 0x0000F0 specifies 960 data bits. For more information see Section 7.1.4, "Viterbi Bit Error Rate Monitor."

#### Read/Write: R/W



#### 3.6.7 Group 4, APR 8 Viterbi Maximum Bit Error Count

VMBEC specifies the maximum number of (Viterbi symbol errors/128 + 32) that are allowed to occur within the data period set by VMDC1 (Group 4, APR 4) to achieve Viterbi module synchronization. Whenever the symbol error count from the internal bit error counter exceeds the value VMBEC, the synchronization module concludes that the Viterbi decoder module is out of synchronization and proceeds to adjust the phase of the incoming symbol stream until synchronization is reached. For example, a value of VMBEC[7:0] = 0b00000011 specifies 416 errors. For more information see Equation 7.1 in Section 7.1.4, "Viterbi Bit Error Rate Monitor."

#### Read/Write: R/W



#### 3.6.8 Group 4, APR 9 Synchronization Word

This register contains the synchronization word used by the synchronization module in stages two and three. Within this byte, the MSB is oldest chronologically, and the LSB the newest.

#### Read/Write: R/W



This register is used to set the maximum number of mismatching bits allowed to declare a match when comparing the data stream to the reference synchronization word during the tracking phase in the second synchronization stage.

Read/Write: R/W

APR D7 D6 D5 D4 D3 D2 D1 D0 10 Set to 0 Reserved L[1:0] Set to 0 Set to 0 7 This is an internal test bit and should be set to 0 for normal operation. Reserved **Reserved Bits** [6:2] These bits are reserved for LSI Logic internal use only. Reserved bits should always be set to 0, and will produce random results when read. L[1:0] Mismatching Bits, Tracking Mode, Sync 2 [1:0] This field is used to set the maximum number of mismatching bits allowed to declare a match when comparing eight bits in the data stream to the reference synchronization word during tracking phase in the second synchronization stage. L can be configured from 0 to 2. A higher value of L results in a smaller probability of loss of lock due to random noise, a lower value in a higher probability of loss. **Data Bits** Number of D1 **D0 Mismatching Bits** 0 0 0 0 1 1

2

Illegal Value

Group 4, APR 10 BER Monitor and Mismatching Bits in Sync 2 Tracking Mode

3.6.9

1

1

0

1

This register is used to select which algorithms will be used in the synchronization modules, and which module's synchronization status will be shown on the SYNC output pin. It also selects the frequency of the clock Synchronization that will be output on the BCLKOUT pin.

#### Read/Write: R/W

| APR | D7 | D6       | D5  | D4    | D3  | D2    | D1  | D0    |
|-----|----|----------|-----|-------|-----|-------|-----|-------|
| 11  | BF | Set to 0 | SSS | [1:0] | SSA | [1:0] | SST | [1:0] |

BF

3.6.10

Group 4,

States and

BCLKOUT Format

**APR 11** 

#### BCLKOUT Format

When you set this bit to 1, the BCLKOUT pin outputs a continuous clock waveform with a 50% duty cycle at 1/8 the OCLK frequency. It is typically used by a downstream device that runs on a byte-clock rather than on a bit clock. The DVALIDOUT pin needs to be observed to identify valid data bytes. When you set this bit to 0, the BCLK-OUT produces a rising edge for every valid data bit on the CO0 output pin (Serial Output Channel mode). The downstream device can use BCLKOUT as a data latching strobe without the need to inspect DVALIDOUT.

7

6

#### Data Bits BCLKOUT

| D7 | Function:        | Operating Mode          |
|----|------------------|-------------------------|
| 1  | Continuous Clock | Serial Output Channel   |
| 0  | Data Strobe      | Parallel Output Channel |

#### Set to 0 Set to 0

You should set this bit LOW for proper operation.

SSS[1:0] Synchronization Status Select [5:4] You can observe the synchronization status of one of the three synchronization modules on the SYNC output pin: Viterbi decoder synchronization, Deinterleaver/Reed-Solomon decoder synchronization, and Descrambler synchronization. You program the SSS field to determine

which one of these three synchronization status bits will be propagated to the SYNC pin.

Data Bits D5 D4 SYNC Pin Connected to

| 0 | 0 | Viterbi Decoder Synchronization |
|---|---|---------------------------------|
| 0 | 1 | DI/RS Decoder Synchronization   |
| 1 | 0 | Descrambler Synchronization     |

**SSA[1:0]** Synchronization States, Acquisition Mode [3:2] The second synchronization module (after the Viterbi Decoder, before the Deinterleaver module) allows three different state diagrams to be used in the acquisition phase. The number of properly identified synchronization words that will cause "in-synchronization" to be declared can be configured from 3 to 6. For more information see Section 6.3, "Reed-Solomon Deinterleaver Synchronization."

#### Data Bits Number of Sync Words D3 D2 Found to Acquire

| 20 |   | i culta to Acquito |  |
|----|---|--------------------|--|
| 0  | 0 | 3                  |  |
| 0  | 1 | 4                  |  |
| 1  | 0 | 5                  |  |
| 1  | 1 | 6                  |  |

**SST[1:0]** Synchronization Status, Tracking Mode [1:0] The second synchronization module (after the Viterbi decoder and before the Deinterleaver module) allows two, three, four, or five undetected synchronization words before the L64704 declares a loss of sync. For more information see Section 6.3, "Reed-Solomon Deinterleaver Synchronization."

| Data | Bits | Number of Missed Sync |
|------|------|-----------------------|
| D1   | D0   | Words to Loss of Lock |

| וט | 00 | WOIDS TO LOSS OF LOCK |
|----|----|-----------------------|
| 0  | 0  | 2                     |
| 0  | 1  | 3                     |
| 1  | 0  | 4                     |
| 1  | 1  | 5                     |
| -  |    |                       |

This register is used to configure the Channel output data path.

Group 4, APR 12 Output Control

3.6.11

#### Read/Write: R/W

APR D7 D6 D5 D4 D3 D2 D1 D0 12 BPS[2:0] Set to 0 OF OS[2:0] BPS[2:0] Symbol Size for Viterbi Bypass Mode [7:5] You should set these bits to 0 for proper operation. Set to 0 Set to 0 4 You should set this bit to 0 for proper operation. OF **Descrambler Output Format** 3 Writing to this bit sets the descrambler output mode: D3 Data Bit CO[7:0] Channel Output Mode 0 Serial Channel Output Mode Parallel Channel Output Mode 1

> In Serial Channel Output mode, one bit of decoded data is presented on CO0 every OCLK cycle. In Parallel Channel Output mode, one byte of decoded data is presented on CO[7:0] every eight OCLK cycles.

#### OS[2:0] Output Selector [2:0] The output of several major functional blocks can be observed on the channel output (CO[7:0] in Parallel Channel Output mode, CO0 in Serial Channel Output mode). For a detailed description of the signals observed for the cases below, see Section 4.5, "Data Path Output Configurations."

#### Data Bits

| D2 | D1 | <b>D0</b> | Definition                                                         |
|----|----|-----------|--------------------------------------------------------------------|
| 0  | 0  | 0         | Descrambler Module Output                                          |
| 0  | 0  | 1         | Descrambler Module Synchronization (Sync 3)<br>Output              |
| 0  | 1  | 0         | RS Decoder Output                                                  |
| 0  | 1  | 1         | Deinterleaver Module Output                                        |
| 1  | 0  | 0         | Deinterleaver/RS Synchronization (Sync 2) Output                   |
| 1  | 0  | 1         | Viterbi Decoder Module Output                                      |
| 1  | 1  | 0         | Viterbi Synchronization/Decoder Synchronization<br>(Sync 1) Output |

| D2D1D0Definition111BPSK/QPSK Demodulator Output | Dat | a Bi | ts |                              |
|-------------------------------------------------|-----|------|----|------------------------------|
| 1 1 1 BPSK/QPSK Demodulator Output              | D2  | D1   | D0 | Definition                   |
|                                                 | 1   | 1    | 1  | BPSK/QPSK Demodulator Output |

3.6.12 Writing any value to APR 13 generates an internal reset pulse for the
Group 4, PLL module. The L64704 ignores any data on the D[7:0] bus during a
APR 13 write to this register. You should reset the PLL module before operation.
PLL Reset

The PLL Reset register (APR 13) cannot be read.

#### Read/Write: Write Only

| APR | D7 | D6 | D5 | D4    | D3    | D2 | D1 | D0 |
|-----|----|----|----|-------|-------|----|----|----|
| 13  |    |    |    | PLL_F | RESET |    |    |    |

The Clock Loop Control 1 register is used to set clock parameters related to the Demodulator module carrier synchronization logic.

Read/Write: R/W

#### APR D7 D6 D5 D4 D3 D2 D1 D0 F OUT CLK LCFICLK VCO SYNC/ 14 Reserved Set to 0 CLK\_DR[1:0] SCLK HiZ Suppress SWAP

#### SYNC/SCLK SYNC Pin Output Select

Use this pin to select the signal that you want to appear on the SYNC pin:

| D7 | Output | When Used                |
|----|--------|--------------------------|
| 0  | SYNC   | Normal Operation         |
| 1  | SCLK   | Low Baud Rate Operations |

When this bit is set to 0, the SYNC pin carries the signal selected by the Synchronization Status Select bits SSS[1:0] (Group 4, APR 11). When this bit is set to 1, the SYNC pin carries the symbol clock of the demodulator, SCLK, that is used to clock the external DAC during low baud rate operation. For more information see Section 5.6.2.3, "Low Baud Rate Operation."

#### 3.6.13 Group 4, APR 14 Clock Loop Control 1

7

| Reserved | <b>Reserved Bits</b><br>These bits are reserved for LSI Logic internal use only.<br>Reserved bits should always be set to 0, and will produce<br>random results when read. | 5 |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Set to 0 | Set to 0                                                                                                                                                                   | 5 |

You should set this bit to 0 for proper operation.

 F\_OUT\_HiZ
 Functional Outputs 3-stated
 4

 Set this bit to put the CLK\_VCOP/N pins into a high impedance condition.
 4

#### D4 Definition

0 Normal

1 Hi-Z

#### CLK\_LCF\_Suppress

CLK\_LCF\_Suppress in Timing Error Detector 3 Set this bit to disable the Automatic Frequency Controller (AFC). For more information see Section 5.5.2, "Clock Acquisition and Tracking Modes."

#### D3 Definition

- 0 Normal
- 1 Suppressed

#### CLK\_VCO\_SWAP

#### **CLK Outputs Polarity Swap**

2

Program this bit to set the polarity of the clock output pins CLK\_VCOP/N. For more information see Section 5.5, "Channel Clock Recovery."

#### D2 Definition

- 0 Normal
- 1 Swapped

#### CLK\_DR[1:0] Decimation Filter Select [1:0] Program the Decimation Filter Select field to set the

Program the Decimation Filter Select field to set the amount of decimation, and therefore the oversampling ratio. For more information see Section 5.3, "Decimation Filters."

| D1 | D0 | Decimation | Oversampling<br>Ratio |
|----|----|------------|-----------------------|
| 0  | 0  | none       | 2                     |
| 0  | 1  | 1/2        | 4                     |
| 1  | 0  | 2/3        | 3                     |
| 1  | 1  | Illegal    |                       |

3.6.14 The Clock Loop Control 2 register is used to set clock parameters related Group 4, to the Demodulator module Automatic Frequency Control (AFC) and APR 15 external phase-locked loop. It also contains the power-down control bit. **Clock Loop** Control 2

Read/Write: R/W

| APR      | D7       | D6                                                                                                                                                                                                                                                                                                                          | D5                                                                                                                                                                                                                                                                                                                                                                                                                   | D4             | D3          | D2    | D1      | D0 |  |  |
|----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------------|-------|---------|----|--|--|
| 15       | Set to 0 | PCLK_<br>BP                                                                                                                                                                                                                                                                                                                 | Set to 0                                                                                                                                                                                                                                                                                                                                                                                                             | PD             |             | CLK_F | RP[3:0] |    |  |  |
| Set to 0 |          |                                                                                                                                                                                                                                                                                                                             | Set to 07You should set this bit to 0 for proper operation.                                                                                                                                                                                                                                                                                                                                                          |                |             |       |         |    |  |  |
| PCLK_BP  |          | PCLK Bypass 6<br>When you set this bit to 0, the PCLK output pin carries<br>the clock signal generated by the internal PLL module.<br>When you set this bit to 1, PCLK presents SCLK at the<br>output and bypasses the internal PLL module. For a block<br>diagram see Section 4.1, "Data Control and Clocking<br>Schemes." |                                                                                                                                                                                                                                                                                                                                                                                                                      |                |             |       |         |    |  |  |
| Set to 0 |          | Set to 05You should set this bit to 0 for proper operation.                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                      |                |             |       |         |    |  |  |
| PD       |          | When<br>asynch<br>reduce<br>cessin<br>Power<br>a rese                                                                                                                                                                                                                                                                       | <b>Power-Down</b> 4<br>When you set Power-Down to 1, all modules except the<br>asynchronous microprocessor interface are turned off to<br>reduce power consumption to a minimum. No data pro-<br>cessing can occur during Power-Down. When you set<br>Power-Down to 0 all elements operate. You should apply<br>a reset pulse after you change Power-Down from 1 to 0<br>(wake-up) before you start processing data. |                |             |       |         |    |  |  |
|          |          | Defini                                                                                                                                                                                                                                                                                                                      | tion                                                                                                                                                                                                                                                                                                                                                                                                                 |                | D4          | _     |         |    |  |  |
|          |          |                                                                                                                                                                                                                                                                                                                             | al Operations in Powe                                                                                                                                                                                                                                                                                                                                                                                                | on<br>r-Down M | 0<br>lode 1 |       |         |    |  |  |

#### CLK\_RP[3:0] Reference Period for Clock AFC [3:0] CLK\_RP presets the four MSBs of the reference counter. See Section 5.5.2, "Clock Acquisition and Tracking Modes" for details.

**3.6.15**A counter in the AFC decrements once each VCO clock edge during the<br/>reference period. Set the counter's initial value using the 16-bit CLK\_NF**APR 16, 17**register where bit 7 of APR 16 is the MSB, and bit 0 of APR 17 is the LSB.<br/>See Section 5.5.2, "Clock Acquisition and Tracking Modes" for details.

#### Read/Write: R/W



### 3.6.16 This register is used to set the input decimation factor for the RI and the Group 4, RQ inputs.APR 18

Clock Ratio

Frequency of

**Clock Input** 

Read/Write: R/W

| APR | D7       | D6 | D5 | D4 | D3 | D2 | D1        | D0   |
|-----|----------|----|----|----|----|----|-----------|------|
| 18  | Reserved |    |    |    |    | CL | K_RATIO[2 | 2:0] |

Reserved Reserved [7:3] These bits are reserved for LSI Logic internal use only. Reserved bits should always be set to 0, and will produce random results when read.

#### CLK\_RATIO[2:0]

**Input Decimation Factor for RI and RQ Inputs** [2:0] This field sets the input decimation factor for the RI and the RQ inputs. For more information see Section 5.5.1, "Input Decimation."

| D2 | D1 | D0 | Definition                |
|----|----|----|---------------------------|
| 0  | 0  | 0  | No Decimation             |
| 0  | 0  | 1  | Input Every Second Sample |
| 0  | 1  | 0  | Input Every Fourth Sample |
|    |    |    |                           |

| D2 | D1 | D0 | Definition                   |
|----|----|----|------------------------------|
| 0  | 1  | 1  | Input Every Eighth Sample    |
| 1  | 0  | 0  | Input Every Sixteenth Sample |
| 1  | 0  | 1  | Illegal                      |
| 1  | 1  | 0  | Illegal                      |
| 1  | 1  | 1  | Illegal                      |

**3.6.17**This register sets the reference power level for the Analog to Digital**Group 4,**Convertor. For details on setting this register, see Section 5.7.1, "ADC**APR 19**Range and Power Reference."**Power** 

Reference Level Read/Write: R/W

Read/Write: R/W



This register is used to enable internal DC offset compensation on the I and Q signals and set the power estimation bandwidth.

3.6.18 Group 4, APR 20 Power Estimation Bandwidth and I/Q DC Offset

| APR                                                                                                                                                                       | D7 | D6     | D5                                     | D4       | D3 | D2      | D1    | D0                   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--------|----------------------------------------|----------|----|---------|-------|----------------------|
| 20                                                                                                                                                                        |    |        | Reserved                               |          |    | INT_ DC | PWR_E | 3W[1:0]              |
| Reserved         Reserved           These bits are reserved for LSI Logic inter           Reserved bits should always be set to 0, ar           random results when read. |    |        |                                        |          |    |         |       |                      |
| INT_DC                                                                                                                                                                    |    | Set th | hal DC Of<br>his bit to e<br>and Q sig | nable in | •  |         |       | <b>2</b><br>ation on |
|                                                                                                                                                                           |    | D2     | Definition                             | _        |    |         |       |                      |
|                                                                                                                                                                           |    | 0<br>1 | Disabled<br>Enabled                    | _        |    |         |       |                      |

# PWR\_BW[1:0] Power Estimation Bandwidth

[1:0]

Program these bits to set the power estimation bandwidth. For more information see Section 5.7.2, "Power Control Loop."

| D1 | D0 | Symbol Rate (MHz) |
|----|----|-------------------|
| 0  | 0  | 20 - 45           |
| 0  | 1  | 10 - 20           |
| 1  | 0  | 5 - 10            |
| 1  | 1  | 2 - 5             |

| 3.6.19<br>Group 4,                                     | Program these bits to set the scale factor for the DEMI and DEMQ outputs from the Demodulator to the FEC Decoder. For a relationship |
|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| APR 21<br>Scale Factor for<br>DEMI and<br>DEMQ Outputs | between SCALE and PWR_REF, see Section 5.8, "Output Control."<br>Read/Write: R/W                                                     |

| APR | D7 | D6 | D5 | D4   | D3     | D2 | D1 | D0 |
|-----|----|----|----|------|--------|----|----|----|
| 21  |    |    |    | SCAL | E[7:0] |    |    |    |

| 3.6.20        | Use this register to set the value that the phase detector's Signal to    |
|---------------|---------------------------------------------------------------------------|
| Group 4,      | Noise Ratio (SNR) comparator uses as a threshold when deciding which      |
| APR 22        | gain value to use. For details, see Figure 5.7 in Section 5.6.2, "Carrier |
| SNR Estimator | Phase Tracking."                                                          |
| Threshold     |                                                                           |

# Read/Write: R/W

| APR | D7 | D6 | D5 | D4    | D3      | D2 | D1 | D0 |
|-----|----|----|----|-------|---------|----|----|----|
| 22  |    |    |    | SNR_T | HS[7:0] |    |    |    |

3.6.21 Use this register to establish a DC offset voltage that is added to or sub-tracted from the carrier loop voltage. The value stored in this register is a signed integer that ranges from -128 to +127. For details, see Section 5.9.1, "Carrier Loop DC Offset Compensation."
 Offset
 Compensation

Value

# Read/Write: R/W

Read/Write: R/W

| APR | D7 | D6 | D5 | D4     | D3        | D2 | D1 | D0 |
|-----|----|----|----|--------|-----------|----|----|----|
| 23  |    |    |    | CAR_OF | FSET[7:0] |    |    |    |

This register is used to program the preset value for the frequency sweep reference counter.

Group 4, APR 24 Carrier Frequency Reference Period

3.6.22

| APR _ | D7 | D6   | D5    | D4 | D3          | D2 | D1 | D0 |
|-------|----|------|-------|----|-------------|----|----|----|
| 24    |    | Rese | erved |    | CAR_RP[3:0] |    |    |    |

# Reserved Bits [7:4] These bits are reserved for LSI Logic internal use only. Reserved bits should always be set to 0, and will produce random results when read.

# CAR\_RP[3:0] Reference Period for Carrier Frequency (CAR\_DCLKP/N pin) Measurement [3:0] Program the preset value for the four MSBs of the frequency sweep reference counter into this register. The value programmed equals 1024 times the number of crystal (XOIN) clock cycles. See Section 5.6.1, "Carrier Acquisition."

| 3.6.23<br>Group 4,<br>APR 25, 26<br>Carrier Loop<br>Filter Gain<br>(P and D Terms) | the car<br>127 in | rrier reco | overy loo<br>See <mark>Se</mark> | op. CAR_ | _KP is re | values the<br>estricted to<br>pop Chara | o values | between | 30 and     |
|------------------------------------------------------------------------------------|-------------------|------------|----------------------------------|----------|-----------|-----------------------------------------|----------|---------|------------|
|                                                                                    |                   | 57         | Do                               | 55       | 54        | <b>D</b> o                              | Ba       | 54      | <b>D</b> o |

| APR | D7 | D6 | D5 | D4    | D3                                                   | D2 | D1 | D0 |
|-----|----|----|----|-------|------------------------------------------------------|----|----|----|
| 25  |    |    |    | CAR_ł | <p[7:0]< td=""><td></td><td></td><td></td></p[7:0]<> |    |    |    |

AP 24

| APR | D7 | D6 | D5 | D4    | D3      | D2 | D1 | D0 |
|-----|----|----|----|-------|---------|----|----|----|
| 26  |    |    |    | CAR_ł | KD[7:0] |    |    |    |

 3.6.24
 The value that you program into CAR\_THSL determines the threshold for

 Group 4,
 the Carrier Phase Lock Detector. For details, see Section 5.6.1.5, "Phase

 APR 27
 Lock Detection."

 Carrier Lock
 Read/Write: R/W

 Threshold
 Read/Write: R/W

| APR | D7 | D6 | D5 | D4     | D3       | D2 | D1 | D0 |
|-----|----|----|----|--------|----------|----|----|----|
| 27  |    |    |    | CAR_TH | HSL[7:0] |    |    |    |

**3.6.25**The value that you program into this register determines the Carrier**Group 4**,Synchronizer sweep rate. For details, see Section 5.6.1.4, "Frequency**APR 28**Sweep Rate."**Carrier** 

# Read/Write: R/W



| 3.6.26                                          | You program the CAR_USWL and CAR_LSWL registers to set the upper         |
|-------------------------------------------------|--------------------------------------------------------------------------|
| Group 4,                                        | and lower limits, respectively, of the frequency sweep. For details, see |
| APR 29, 30                                      | Section 5.6.1.1, "Frequency Sweep Limits."                               |
| Carrier<br>Synchronizer<br>Sweep Upper<br>Limit | Read/Write: R/W                                                          |

| APR _ | D7            | D6    | D5             | D4 | D3 | D2 | D1 | D0 |
|-------|---------------|-------|----------------|----|----|----|----|----|
| 29    | Rese          | erved | CAR_USWL[13:8] |    |    |    |    |    |
| APR   | D7            | D6    | D5             | D4 | D3 | D2 | D1 | D0 |
| 30    | CAR_USWL[7:0] |       |                |    |    |    |    |    |

Synchronizer Sweep Rate

# Reserved Reserved Bits [7:6] These bits are reserved for LSI Logic internal use only. Reserved bits should always be set to 0, and will produce random results when read.

# CAR\_USWL[13:0]

# Carrier Sweep Upper Sweep Limit [5:0], [7:0]

Program the CAR\_USWL register to set the upper limit of the frequency sweep.

You program the CAR USWL and CAR LSWL registers to set the upper and lower limits, respectively, of the frequency sweep. For details, see Section 5.6.1.1, "Frequency Sweep Limits."

Read/Write: R/W

Group 4, APR 31. 32 Carrier Synchronizer Sweep Lower Limit

3.6.27



Reserved

## **Reserved Bits**

[7:6] These bits are reserved for LSI Logic internal use only. Reserved bits should always be set to 0, and will produce random results when read.

# CAR LSWL[13:0]

Carrier Sweep Lower Sweep Limit [5:0], [7:0] Program the CAR LSWL register to set the lower limit of the frequency sweep.

3.6.28 This register contains the various control bits that are used to configure Group 4, the Carrier Loop Synchronizer Loop logic. For more information, see **APR 33** Section 5.6, "Carrier Synchronizer."

Carrier Loop Configuration Register

Read/Write: R/W

| APR | D7               | D6               | D5              | D4              | D3              | D2              | D1       | D0     |
|-----|------------------|------------------|-----------------|-----------------|-----------------|-----------------|----------|--------|
| 33  | CAR_SWP_<br>SWAP | CAR_VCO_<br>SWAP | CAR_VCO2<br>N/P | CAR_VCO1<br>N/P | CAR_OUT_<br>SEL | CAR_PED_<br>SEL | CAR_OPEN | CAR_SW |

# CAR SWP SWAP

Swap Carrier Sweep Direction 7 Set this bit to control whether the carrier acquisition frequency sweep direction is normal or reversed. It should be toggled whenever the carrier sweep reaches its limit

without achieving carrier lock, or when the constellation has locked at  $45^{\circ}$ .

# D7 Sweep Direction

| 0 | Normal |
|---|--------|
|---|--------|

1 Reversed

# CAR\_VCO\_SWAP

# Swap VCO Output Polarity

6

Set this bit to invert the polarities of the CAR\_VCOxN/P pins. It should be toggled whenever the carrier sweep reaches its limit without achieving carrier lock, or when the constellation has locked at 45°.

# D6 Polarity

0 Normal

1 Swapped (N and P Inverted)

# CAR\_VCO2N/P

# **Outputs Active or 3-state**

5

Program this bit to enable or disable the outputs of the second Sigma Delta differential pair. For low bit rate applications that use an external DAC, you must enable both Sigma-Delta outputs by setting Carrier Loop Configuration Register bits [5:4] to zero. For more information, see Section 5.6, "Carrier Synchronizer."

# D5 CAR\_VCO2N/P Pins

1 3-state

This bit should always be set to 0 when CAR\_OUT\_SEL is set to 1.

# CAR\_VCO1N/P

# **Outputs Active or 3-state**

4

Program this bit to enable or disable the outputs of the first Sigma Delta differential pair. For low bit rate applications that use an external DAC, you must enable both Sigma-Delta outputs by setting Carrier Loop Configuration Register bits [5:4] to zero. For more information, see Section 5.6, "Carrier Synchronizer."

## D4 CAR\_VCO1N/P Pins

1 3-state

This bit should always be set to 0 when CAR\_OUT\_SEL is set to 1.

# CAR\_OUT\_SEL

# **Carrier Loop Output Selector**

3

Use this bit to route the Phase Error Detector outputs to the Carrier Loop output pins instead of the Sigma-Delta circuit outputs. This allows a full range of frequencies to be decoded by using an external DAC for low baud rate operation. For more information, see Section 5.6.2.3, "Low Baud Rate Operation."

The output pin assignments when using the CAR\_OUT\_SEL bit are:

|                 | CAR_OUT_SEL |           |  |  |  |
|-----------------|-------------|-----------|--|--|--|
| Output Pin Name | 0           | 1         |  |  |  |
| CAR_PED.0       | CAR_PED.0   | CAR_PED.0 |  |  |  |
| CAR_PED.1       | CAR_PED.1   | CAR_PED.1 |  |  |  |
| CAR_VCO1P       | CAR_VCO1P   | CAR_PED.2 |  |  |  |
| CAR_VCO2P       | CAR_VCO2P   | CAR_PED.3 |  |  |  |
| CAR_VCO1N       | CAR_VCO1N   | CAR_PED.4 |  |  |  |
| CAR_VCO2N       | CAR_VCO2N   | CAR_PED.5 |  |  |  |

# CAR\_PED\_SEL

**Carrier Phase Error Detector Select** 

2

Program this bit to select which phase error estimator will be used for carrier phase tracking. For details, see Section 5.6.2, "Carrier Phase Tracking," and Figure 5.9.

# D2 Estimator Selected

- 0 Decision Directed Maximum Likelihood (DDML)
- 1 Non-Data Aided Maximum Likelihood (NDAML)

#### CAR OPEN **Carrier Loop Open**

Set this bit to force the loop out of a false lock condition. For more information see Section 5.6.1.7, "False Locks."

#### D1 Definition

- 0 Enable the Carrier Loop
- 1 Unlock (Disable) the Carrier Loop

#### CAR\_SW Sweep On/off for Carrier Loop 0 Set the CAR\_SW bit to enable the carrier acquisition sweep generator. For more information see Section 5.6.1, "Carrier Acquisition."

#### D0 Definition

- 0 Sweep Off
- 1 Sweep On

3.6.29 This register is reserved for LSI Logic internal use only. You must program the bits as shown during device initialization. Group 4,

# Read/Write: R/W

**APR 34** 

Set to 0

| APR                                                                                            | D7       | D6 | D5 | D4                    | D3      | D2 | D1 | D0 |  |
|------------------------------------------------------------------------------------------------|----------|----|----|-----------------------|---------|----|----|----|--|
| 34                                                                                             | Set to 0 |    |    | Reserved              |         |    |    |    |  |
| Set to 0       Set to 0       [7:5]         You must set these bits to 0 for normal operation. |          |    |    |                       |         |    |    |    |  |
| Reserved Reserved Bits<br>These bits are<br>Reserved bits s<br>random results                  |          |    |    | reserved<br>should al | ways be |    |    |    |  |

1

| 3.6.30<br>Group 4,<br>APR 35<br>Decoder<br>Configuration<br>Register |                                                                                                                                              | This resister contains the various control bits that are used to configure the L64704 Decoder logic. |          |                 |      |     |      |          |
|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|----------|-----------------|------|-----|------|----------|
| APR                                                                  | D7                                                                                                                                           | D6                                                                                                   | D5       | D4              | D3   | D2  | D1   | D0       |
| 35                                                                   | SNR_EST                                                                                                                                      | CON_SEL                                                                                              | Set to 0 | FP_LOCK_<br>LEN | PWRP | Set | to 0 | I_FORMAT |
|                                                                      | SNR_EST       SNR Estimator On/Off       7         Set this bit to enable or disable the SNR Estimator circuit.       D7       SNR Estimator |                                                                                                      |          |                 |      |     |      |          |

0 Off 1 On

# CON\_SELConstellation Selector6Set this bit to indicate the format of the input data.

# D6 Definition

- 0 QPSK
- 1 BPSK

# Set to 0 Set to 0

You must set this bit to 0 for normal operation

# FP\_LOCK\_LEN

# Frequency/Phase Lock Detector Length 4 Program this bit in conjunction with the Carrier Threshold field (Group 4, APR 27) to set the phase lock detector

5

estimation period. For details, see Section 5.6.1.5, "Phase Lock Detection."

# D4 Estimation Period

- 0 Normal (Long)
- 1 Short

| PWRP     | PWRP Signal Invert3Set this bit to invert the polarity of the signal that is outputon the PWRP pin. |
|----------|-----------------------------------------------------------------------------------------------------|
|          | D4 PWRP Output Pin                                                                                  |
|          | 0 Normal<br>1 Inverted                                                                              |
| Set to 0 | Set to 0[2:1]You must set these bits to 0 for normal operation                                      |
| I_FORMAT | Input Format Selector 0<br>Program this bit to tell the L64704 the format of the incoming data.     |
|          | D0 Input Format                                                                                     |
|          | <ul> <li>RI and RQ in Offset Binary Format</li> <li>RI and RQ in 2's Complement Format</li> </ul>   |

**3.6.31**This register contains the control bits for the external output pins**Group 4,**XCTR\_OUT[3:0] and the bits that reset the demodulator and FEC**APR 36**circuitry.**External Output** 

APR 36 External Output Control Bits and Reset Register

Read/Write: R/W

| APR                                                                                                                                                                                                         | D7     | D6               | D5                                 | D4        | D3                                                | D2       | D1     | D0          |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------|------------------------------------|-----------|---------------------------------------------------|----------|--------|-------------|
| 36                                                                                                                                                                                                          | Rese   | erved            |                                    | XCTR[3:0] |                                                   |          |        | FEC_<br>RST |
| Reserved         Reserved Bits         [7:6]           These bits are reserved for LSI Logic internal use only.         Reserved bits should always be set to 0, and will produce random results when read. |        |                  |                                    |           |                                                   |          |        | •           |
| XCT                                                                                                                                                                                                         | R[3:0] | The va<br>the co | alue that<br>rrespond<br>ection 5. | ding exte | out Bits<br>on a bit in<br>rnal outp<br>ternal Co | ut pin X | CTR_OU |             |

| XCTR | Definition                     |
|------|--------------------------------|
| 0    | Corresponding Output Pin = VSS |
| 1    | Corresponding Output Pin = VDD |

# DEMOD\_RST QPSK Demodulator Software Reset

The L64704 resets the internal datapath and control modules for the QPSK Demodulator portion of the device when you set the DEMOD\_RST bit to 1. The FEC decoder module is not affected. You do not need to set the bit back to 0 to complete the reset. The L64704 issues a single reset pulse each time the microcontroller writes a one to this bit. When the DEMOD\_RST bit is set, the L64704 resets the demodulator processing unit and state machines to their initial states.

| Demod_Reset | Definition                        |
|-------------|-----------------------------------|
| 0           | No Reset                          |
| 1           | L64704 Issues a Demodulator Reset |

# FEC\_RST FEC Decoder Software Reset

The L64704 resets the internal datapath and control modules for the FEC portion of the device when you set the FEC\_RST bit to 1. The demodulator module is not affected. You do not need to set the bit back to 0 to complete the reset. The L64704 issues a single reset pulse each time the microcontroller writes a one to this bit. When the FEC\_RST bit is set, the L64704 resets the FEC processing unit and state machines to their initial states.

| FEC_Reset | Definition                 |
|-----------|----------------------------|
| 0         | No Reset                   |
| 1         | L64704 Issues an FEC Reset |

3-52

0

# Chapter 4 Channel Interfaces and Data Control

The L64704 interface supports two independent interfaces for incoming channel data and for decoded output data. Both interfaces are used simultaneously. The input interface transfers data from an external ADC device to the L64704. The output interface transfers data from the L64704 to the next processing device, typically an MPEG-2 transport demultiplexer such as LSI Logic's L64007. This chapter contains five sections:

- Section 4.1, "Data Control and Clocking Schemes," describes the Channel Data Interface signals and the clock that strobes data into the L64704.
- Section 4.2, "Channel Data Input Interface," provides timing diagrams for the Channel Data input signals.
- Section 4.3, "Channel Data Output Interface," provides timing diagrams for the Channel Data output signals.
- Section 4.4, "PLL Clock Generation," describes the Phase-Locked Loop clock generation circuitry in detail.
- Section 4.5, "Data Path Output Configurations," shows how to program the output data path multiplexer to carry the outputs of the various stages of the decoding pipeline.

4.1The L64704 uses two input clock signals, CLK and OCLK, to accommo-<br/>date a number of possible configurations in a channel decoding system.<br/>CLK is generated by the external Clock VCO and can be two, three, or<br/>four times the symbol rate. There is also an internally generated symbol<br/>clock, SCLK.

OCLK is the Forward Error Correction clock. Its relation to CLK is determined by the Viterbi puncture rate and the number of samples per symbol at the ADC. An on-chip PLL generates the desired OCLK frequency and outputs it to the PCLK output (see Figure 4.1). You should connect the PCLK output pin to the OCLK input pin.





You can also generate the desired OCLK signal using an external PLL (see Figure 4.2). In that case the PCLK pin should be set to output the symbol rate clock, SCLK. The external PLL frequency is a function of the Viterbi puncture rate.





Figure 4.3 and Figure 4.4 show several clocking examples. Figure 4.3 shows a case where the input data rate is 1/2 the data processing rate in the decoding pipeline. The FEC FIFO input and FIFO output data streams run at the same rate because no extra information (erasures) need to be added after the FIFO. The CLK and OCLK signals do not need to be aligned in phase.



Figure 4.4 illustrates a case where the input data rate is set to 3/4 of the data processing rate in the decoding pipeline. Because the depuncturing logic inserts extra symbols (erasures), the L64704 transmits the symbols from the FIFO in small bursts at the higher clock rate (OCLK). After leaving the Viterbi Decoder, the data stream becomes continuous at the OCLK rate.





Figure 4.4 shows a case in which the data rate ratios shown are maintained, the incoming data stream is continuous, and the decoder fixes the frequency of OCLK at twice that of CLK. Because the decoder reads the FIFO at the OCLK frequency— which is greater than the Viterbi code rate—the FIFO empties periodically. The data pipeline is designed to handle such internal interruptions in the data stream without corrupting data that is already being processed. As a consequence, the channel output data appears in bursts at the OCLK rate, but on average maintains the data rate imposed by the Viterbi Decoder. The DVALIDOUT signal indicates when valid data is on the CO[7:0] output.



# 4.3 Channel Data **Output Interface**

Figure 4.6

Output

to Channel Data

Figure 4.6 shows how the channel data output signals CO[7:0], DVALID-OUT, ERROROUT, and FSTARTOUT are referenced to OCLK.



Figure 4.7 shows that new data is valid on the output whenever the L64704 asserts DVALIDOUT. The L64704 deasserts DVALIDOUT when it transfers parity and gap data. When the L64704 detects an uncorrectable error, it asserts ERROROUT while it transmits both data and parity bytes.



The L64704 asserts FSTARTOUT when it transfers the first bit of the first symbol of every frame. The frame structure does not require a gap, and the decoding process does not affect the gap bytes.

# 4.4 PLL Clock Generation

The data control and clocking schemes presented in Section 4.1, "Data Control and Clocking Schemes," outline the requirements for the generation of the two external clock signals (CLK and OCLK) that are required by the L64704. You have to choose whether to provide an externally generated clock to the OCLK input or to use the internal PLL for clock synthesis. The internal PLL is selected by connecting the PLL output pin (PCLK) to the OCLK input pin as shown in Figure 4.8 and in Figure 4.1.

Using the internal PLL clock feature allows the L64704 to consume the minimum amount of power.



The L64704 contains a clock synthesizer to derive OCLK from SCLK operating in the range of 2 MHz to 62.5 MHz (see Figure 4.9). The synthesized clock is available on the PCLK output pin.

The PLL can be configured to handle clock ratios for the Viterbi code rates of 1/2, 2/3, 3/4, 5/6, and 7/8. The following four registers must be set to derive the appropriate clock frequencies:

- ◆ PLL\_T[4:0], Group 4, APR 2
- PLL\_N[5:0], Group 4, APR 0
- ◆ PLL\_S[5:0], Group 4, APR 1
- ◆ PLL\_M[1:0], Group 4, APR 3

Figure 4.8

PLL Clock

Generation

| Table 4.1<br>CLK/SCLK Ratio | CLK_RATIO[2:0]<br>Group 4, APR 18 | CLK_DR[1:0]<br>Group 4, APR 14 | Ratio<br>CLK/SCLK |
|-----------------------------|-----------------------------------|--------------------------------|-------------------|
|                             | 0                                 | 0                              | 2                 |
|                             | 1                                 | 0                              | 4                 |
|                             | 2                                 | 0                              | 8                 |
|                             | 3                                 | 0                              | 16                |
|                             | 4                                 | 0                              | 32                |
|                             | 0                                 | 1                              | 4                 |
|                             | 1                                 | 1                              | 8                 |
|                             | 2                                 | 1                              | 16                |
|                             | 3                                 | 1                              | 32                |
|                             | 4                                 | 1                              | 64                |
|                             | 0                                 | 2                              | 3                 |
|                             | 1                                 | 2                              | 6                 |
|                             | 2                                 | 2                              | 12                |
|                             | 3                                 | 2                              | 24                |
|                             | 4                                 | 2                              | 48                |

Table 4.1 shows the ratio of CLK to SCLK.



The recommended values for PLL\_S, PLL\_N, PLL\_T, and PLL\_M to cover the frequency range from 2 to 62.5 MHz for PCLK are tabulated in Table 4.2.

# Table 4.2 Values for PLL\_S, PLL\_N, PLL\_T, and PLL\_M

| Cada         |            |            |            |            | V   | 0   | SC    | LK    | PC                 | LK                 |
|--------------|------------|------------|------------|------------|-----|-----|-------|-------|--------------------|--------------------|
| Code<br>Rate | PLL_S[5:0] | PLL_N[5:0] | PLL_T[4:0] | PLL_M[1:0] | Min | Max | Min   | Max   | Min                | Мах                |
| 1/2          | 2          | 1          | 2          | 3          | 70  | 80  | 70.00 | 80.00 | 70.00 <sup>1</sup> | 80.00 <sup>1</sup> |
|              |            |            |            | 2          | 60  | 70  | 60.00 | 70.00 | 60.00              | 70.00 <sup>1</sup> |
|              |            |            |            | 1          | 50  | 60  | 50.00 | 60.00 | 50.00              | 60.00              |
|              |            |            |            | 0          | 40  | 50  | 40.00 | 50.00 | 40.00              | 50.00              |
|              | 4          | 2          | 2          | 3          | 70  | 80  | 35.00 | 40.00 | 35.00              | 40.00              |
|              |            |            |            | 2          | 60  | 70  | 30.00 | 35.00 | 30.00              | 35.00              |
|              |            |            |            | 1          | 50  | 60  | 25.00 | 30.00 | 25.00              | 30.00              |
|              |            |            |            | 0          | 40  | 50  | 20.00 | 25.00 | 20.00              | 25.00              |
|              | 8          | 4          | 2          | 3          | 70  | 80  | 17.50 | 20.00 | 17.50              | 20.00              |
|              |            |            |            | 2          | 60  | 70  | 15.00 | 17.50 | 15.00              | 17.50              |
|              |            |            |            | 1          | 50  | 60  | 12.50 | 15.00 | 12.50              | 15.00              |
|              | 12         | 6          | 2          | 3          | 70  | 80  | 11.67 | 13.33 | 11.67              | 13.33              |
|              |            |            |            | 2          | 60  | 70  | 10.00 | 11.67 | 10.00              | 11.67              |
|              | 16         | 8          | 2          | 3          | 70  | 80  | 8.75  | 10.00 | 8.75               | 10.00              |
|              |            |            |            | 2          | 60  | 70  | 7.50  | 8.75  | 7.50               | 8.75               |
|              |            |            |            | 1          | 50  | 60  | 6.25  | 7.50  | 6.25               | 7.50               |
|              |            |            |            | 0          | 40  | 50  | 5.00  | 6.25  | 5.00               | 6.25               |
|              | 20         | 10         | 2          | 0          | 40  | 50  | 4.00  | 5.00  | 4.00               | 5.00               |
|              | 24         | 12         | 2          | 0          | 40  | 50  | 3.33  | 4.17  | 3.33               | 4.17               |
|              | 28         | 14         | 2          | 0          | 40  | 50  | 2.86  | 3.57  | 2.86               | 3.57               |
|              | 32         | 16         | 2          | 0          | 40  | 50  | 2.50  | 3.12  | 2.50               | 3.12               |
|              | 36         | 18         | 2          | 0          | 40  | 50  | 2.22  | 2.78  | 2.22               | 2.78               |
|              | 40         | 20         | 2          | 0          | 40  | 50  | 2.00  | 2.50  | 2.00               | 2.50               |
| (Sheet       | t 1 of 4)  |            |            |            |     |     |       |       |                    |                    |

# Table 4.2 (Cont.) Values for PLL\_S, PLL\_N, PLL\_T, and PLL\_M

| Code   |            |            |            |            | V   | 0   | SCLK  |       | PCLK               |                    |
|--------|------------|------------|------------|------------|-----|-----|-------|-------|--------------------|--------------------|
|        | PLL_S[5:0] | PLL_N[5:0] | PLL_T[4:0] | PLL_M[1:0] | Min | Max | Min   | Max   | Min                | Мах                |
| 2/3    | 8          | 1          | 6          | 3          | 70  | 80  | 52.50 | 60.00 | 70.00 <sup>1</sup> | 80.00 <sup>1</sup> |
|        |            |            |            | 2          | 60  | 70  | 45.00 | 52.50 | 60.00              | 70.00 <sup>1</sup> |
|        |            |            |            | 1          | 50  | 60  | 37.50 | 45.00 | 50.00              | 60.00              |
|        |            |            |            | 0          | 40  | 50  | 30.00 | 37.50 | 40.00              | 50.00              |
|        | 16         | 2          | 6          | 3          | 70  | 80  | 26.25 | 30.00 | 35.00              | 40.00              |
|        |            |            |            | 2          | 60  | 70  | 22.50 | 26.25 | 30.00              | 35.00              |
|        |            |            |            | 1          | 50  | 60  | 18.75 | 22.50 | 25.00              | 30.00              |
|        |            |            |            | 0          | 40  | 50  | 15.00 | 18.75 | 20.00              | 25.00              |
|        |            | 6          | 2          | 1          | 50  | 60  | 6.25  | 7.50  | 8.33               | 10.00              |
|        |            |            |            | 0          | 40  | 50  | 5.00  | 6.25  | 6.67               | 8.33               |
|        | 32         | 4          | 6          | 3          | 70  | 80  | 13.12 | 15.00 | 17.50              | 20.00              |
|        |            |            |            | 2          | 60  | 70  | 11.25 | 13.12 | 15.00              | 17.50              |
|        |            |            |            | 1          | 50  | 60  | 9.38  | 11.25 | 12.50              | 15.00              |
|        |            |            |            | 0          | 40  | 50  | 7.50  | 9.38  | 10.00              | 12.50              |
|        |            | 12         | 2          | 3          | 70  | 80  | 4.38  | 5.00  | 5.83               | 6.67               |
|        |            |            |            | 2          | 60  | 70  | 3.75  | 4.38  | 5.00               | 5.83               |
|        |            |            |            | 1          | 50  | 60  | 3.12  | 3.75  | 4.17               | 5.00               |
|        |            |            |            | 0          | 40  | 50  | 2.50  | 3.12  | 3.33               | 4.17               |
|        | 48         | 18         | 2          | 1          | 50  | 60  | 2.08  | 2.50  | 2.78               | 3.33               |
|        |            |            |            | 0          | 48  | 50  | 2.00  | 2.08  | 2.67               | 2.78               |
| 3/4    | 6          | 1          | 4          | 3          | 70  | 80  | 46.67 | 53.33 | 70.00 <sup>1</sup> | 80.00 <sup>1</sup> |
|        |            |            |            | 2          | 60  | 70  | 40.00 | 46.67 | 60.00              | 70.00 <sup>1</sup> |
|        |            |            |            | 1          | 50  | 60  | 33.33 | 40.00 | 50.00              | 60.00              |
|        |            |            |            | 0          | 40  | 50  | 26.67 | 33.33 | 40.00              | 50.00              |
|        |            | 2          | 2          | 3          | 70  | 80  | 23.33 | 26.67 | 35.00              | 40.00              |
|        |            |            |            | 2          | 60  | 70  | 20.00 | 23.33 | 30.00              | 35.00              |
|        |            |            |            | 1          | 50  | 60  | 16.67 | 20.00 | 25.00              | 30.00              |
|        |            |            |            | 0          | 40  | 50  | 13.33 | 16.67 | 20.00              | 25.00              |
| (Sheet | 2 of 4)    |            |            |            |     |     |       |       |                    |                    |

# Table 4.2 (Cont.) Values for PLL\_S, PLL\_N, PLL\_T, and PLL\_M

| Code  |            |            |            |            | V   | 0   | SC    | LK    | PCLK               |                    |
|-------|------------|------------|------------|------------|-----|-----|-------|-------|--------------------|--------------------|
|       | PLL_S[5:0] | PLL_N[5:0] | PLL_T[4:0] | PLL_M[1:0] | Min | Max | Min   | Max   | Min                | Мах                |
| 3/4   | 12         | 4          | 2          | 3          | 70  | 80  | 11.67 | 13.33 | 17.50              | 20.00              |
|       |            |            |            | 2          | 60  | 70  | 10.00 | 11.67 | 15.00              | 17.50              |
|       |            |            |            | 1          | 50  | 60  | 8.33  | 10.00 | 12.50              | 15.00              |
|       |            |            |            | 0          | 40  | 50  | 6.67  | 8.33  | 10.00              | 12.50              |
|       | 18         | 6          | 2          | 1          | 50  | 60  | 5.56  | 6.67  | 8.33               | 10.00              |
|       | 24         | 8          | 2          | 2          | 60  | 70  | 5.00  | 5.83  | 7.50               | 8.75               |
|       |            |            |            | 1          | 50  | 60  | 4.17  | 5.00  | 6.25               | 7.50               |
|       |            |            |            | 0          | 40  | 50  | 3.33  | 4.17  | 5.00               | 6.25               |
|       | 42         | 14         | 2          | 2          | 60  | 70  | 2.86  | 3.33  | 4.29               | 5.00               |
|       |            |            |            | 1          | 50  | 60  | 2.38  | 2.86  | 3.57               | 4.29               |
|       |            |            |            | 0          | 42  | 50  | 2.00  | 2.38  | 3.00               | 3.57               |
| 5/6   | 10         | 1          | 6          | 3          | 70  | 80  | 42.00 | 48.00 | 70.00 <sup>1</sup> | 80.00 <sup>1</sup> |
|       |            |            |            | 2          | 60  | 70  | 36.00 | 42.00 | 60.00              | 70.00 <sup>1</sup> |
|       |            |            |            | 1          | 50  | 60  | 30.00 | 36.00 | 50.00              | 60.00              |
|       |            |            |            | 0          | 40  | 50  | 24.00 | 30.00 | 40.00              | 50.00              |
|       | 20         | 2          | 6          | 3          | 70  | 80  | 21.00 | 24.00 | 35.00              | 40.00              |
|       |            |            |            | 2          | 60  | 70  | 18.00 | 21.00 | 30.00              | 35.00              |
|       |            |            |            | 1          | 50  | 60  | 15.00 | 18.00 | 25.00              | 30.00              |
|       |            |            |            | 0          | 40  | 50  | 12.00 | 15.00 | 20.00              | 25.00              |
|       |            | 6          | 2          | 1          | 50  | 60  | 5.00  | 6.00  | 8.33               | 10.00              |
|       |            |            |            | 0          | 40  | 50  | 4.00  | 5.00  | 6.67               | 8.33               |
|       | 40         | 4          | 6          | 3          | 70  | 80  | 10.50 | 12.00 | 17.50              | 20.00              |
|       |            |            |            | 2          | 60  | 70  | 9.00  | 10.50 | 15.00              | 17.50              |
|       |            |            |            | 1          | 50  | 60  | 7.50  | 9.00  | 12.50              | 15.00              |
|       |            |            |            | 0          | 40  | 50  | 6.00  | 7.50  | 10.00              | 12.50              |
|       |            | 12         | 2          | 3          | 70  | 80  | 3.50  | 4.00  | 5.83               | 6.67               |
|       |            |            |            | 2          | 60  | 70  | 3.00  | 3.50  | 5.00               | 5.83               |
|       |            |            |            | 1          | 50  | 60  | 2.50  | 3.00  | 4.17               | 5.00               |
|       |            |            |            | 0          | 40  | 50  | 2.00  | 2.50  | 3.33               | 4.17               |
| (Shee | t 3 of 4)  |            |            |            |     |     |       |       |                    |                    |

Table 4.2 (Cont.) Values for PLL\_S, PLL\_N, PLL\_T, and PLL\_M

| Code   |            |            |            |            | V   | VCO SCLK |       | PC    | LK                 |                    |
|--------|------------|------------|------------|------------|-----|----------|-------|-------|--------------------|--------------------|
|        | PLL_S[5:0] | PLL_N[5:0] | PLL_T[4:0] | PLL_M[1:0] | Min | Max      | Min   | Max   | Min                | Мах                |
| 7/8    | 14         | 1          | 8          | 3          | 70  | 80       | 40.00 | 45.71 | 70.00 <sup>1</sup> | 80.00 <sup>1</sup> |
|        |            |            |            | 1          | 50  | 60       | 28.57 | 34.29 | 50.00              | 60.00              |
|        |            |            |            | 0          | 40  | 50       | 22.86 | 28.57 | 40.00              | 50.00              |
|        |            | 2          | 4          | 3          | 70  | 80       | 20.00 | 22.86 | 35.00              | 40.00              |
|        |            |            |            | 2          | 60  | 70       | 17.14 | 20.00 | 30.00              | 35.00              |
|        |            |            |            | 1          | 50  | 60       | 14.29 | 17.14 | 25.00              | 30.00              |
|        |            |            |            | 0          | 40  | 50       | 11.43 | 14.29 | 20.00              | 25.00              |
|        |            | 4          | 2          | 3          | 70  | 80       | 10.00 | 11.43 | 17.50              | 20.00              |
|        |            |            |            | 2          | 60  | 70       | 8.57  | 10.00 | 15.00              | 17.50              |
|        |            |            |            | 1          | 50  | 60       | 7.14  | 8.57  | 12.50              | 15.00              |
|        | 28         | 8          | 2          | 3          | 70  | 80       | 5.00  | 5.71  | 8.75               | 10.00              |
|        |            |            |            | 2          | 60  | 70       | 4.29  | 5.00  | 7.50               | 8.75               |
|        |            |            |            | 1          | 50  | 60       | 3.57  | 4.29  | 6.25               | 7.50               |
|        | 42         | 6          | 4          | 3          | 70  | 80       | 6.67  | 7.62  | 11.67              | 13.33              |
|        |            |            |            | 2          | 60  | 70       | 5.71  | 6.67  | 10.00              | 11.67              |
|        |            | 12         | 2          | 3          | 70  | 80       | 3.33  | 3.81  | 5.83               | 6.67               |
|        |            |            |            | 2          | 60  | 70       | 2.86  | 3.33  | 5.00               | 5.83               |
|        |            |            |            | 1          | 50  | 60       | 2.38  | 2.86  | 4.17               | 5.00               |
|        |            |            |            | 0          | 42  | 50       | 2.00  | 2.38  | 3.50               | 4.17               |
| (Sheet | t 4 of 4)  |            |            |            |     |          |       |       |                    |                    |

1. Although the PLL module can generate PCLK frequencies of up to 80 MHz, the maximum OCLK frequency is limited to 62.5 MHz.

# 4.5 The L64704 provides the user with a mechanism to observe the output Data Path of each functional block in the decoding pipeline. This feature simplifies performance characterization and system diagnostics tasks. Figure 4.10 shows the functional blocks in the decoding pipeline.

You can observe the outputs from the Descrambler, Reed-Solomon Decoder, Viterbi Decoder, Deinterleaver Module and the QPSK Demodulator through the CO[7:0], DVALIDOUT, ERROROUT, FSTARTOUT and BCLKOUT output signals. To select an output, the external microcontroller must set the output selector bits in the OS[2:0] (Group 4, APR 12) register to enable the appropriate functional block output. See the description for OS[2:0] on page 3-36 for details. Figure 4.10 L64704 Functional Blocks in the Decoding Pipeline



4.5.1 You can observe the output of the entire decoding pipeline, ending after
 Descrambler
 Output
 Figure 4.12 show the Descrambler output waveforms for Serial Channel
 Output Mode and Parallel Channel Output Mode respectively.

Figure 4.11 Descrambler Serial Output Waveforms



When you set the Output Format bit (Group 4, APR 12) to 0 (Serial Channel Output Mode), the L64704 outputs data bit serially on CO[0]. The L64704 outputs new data one bit per cycle of OCLK (see Figure 4.11). The L64704 asserts FSTARTOUT for one cycle that overlaps the first message bit of a Reed-Solomon code word.





When you set the OF bit to 1 (Parallel Channel Output Mode), the L64704 outputs one new data byte on CO[7:0] every eight OCLK cycles (Figure 4.12). The L64704 chronologically orders the data in Parallel

Channel Output Mode, where the MSB is oldest, and the LSB is newest. The FSTARTOUT strobe overlaps the first data byte. If BF is set (Group 4, APR 11), the L64704 provides BCLKOUT as an additional strobe that has one rising and one falling edge per valid CO[7:0] data byte. The L64704 asserts BCLKOUT in the middle of the decoded data bytes, so the device that receives the output from the L64704 can latch data at the BCLKOUT rate rather than at the OCLK rate. BCLKOUT is a continuous clock output at 1/8 the OCLK frequency when BF is cleared, regardless of whether data is present on the CO[7:0] bus.

# 4.5.2 Synchronization Stage 3 Output

You can observe the outputs of the synchronization stage preceding the Descrambler by setting the OS[2:0] bits to 0b001. Figure 4.13 shows the Synchronization Stage 3 output signals. Signals prefixed by "S3\_" are driven on the pin indicated in parenthesis below the signal name.



In contrast to the Descrambler output, the CO[7:0] bus still carries scrambled data.

# 4.5.3 Reed-Solomon Decoder Output

You can observe the outputs of the Reed-Solomon decoder module by setting the OS[2:0] bits to 0b010. This mode can also be used if you want to bypass the Descrambler entirely. Figure 4.14 shows the Reed-Solomon Decoder output signals. Signals prefixed by "RS\_" are driven on the pin indicated in parenthesis below the signal name.

Figure 4.14 Reed-Solomon Decoder Output Waveforms



# 4.5.4 Deinterleaver Output

You can observe the output signals from the Convolutional Deinterleaver by setting the OS[2:0] bits to 0b011. Figure 4.15 shows the Deinterleaver output waveforms. Signals prefixed by "DI\_" are driven on the pin indicated in parenthesis below the signal name.

Figure 4.15 Deinterleaver Output Waveforms



The L64704 uses the FSTARTOUT, CO[7:0], and DVALIDOUT signals to carry the corresponding Deinterleaver outputs.

4.5.5 You can observe the output of the synchronization stage preceding the Deinterleaver by setting the OS[2:0] bits to 0b100. Synchronization Stage 2 detects the predefined synchronization word to properly align the data stream. Figure 4.16 shows the waveforms for the Synchronization Stage 2 output signals. Signals prefixed by "S2\_" are driven on the pin indicated in parenthesis below the signal name.



You can observe the S2\_INSYNC signal to monitor the state of the second synchronization stage. When the L64704 asserts S2\_INSYNC, it indicates that the decoder has established frame synchronization. When the L64704 deasserts S2\_INSYNC, it indicates an out-of-sync condition.

4.5.6 You can observe the outputs of the Viterbi decoder module by setting the OS[2:0] bits to 0b101. You use this mode to observe the decoded data after only the inner layer of decoding. Figure 4.17 shows the waveforms for the Viterbi Decoder output signals. Signals prefixed by "V\_" are driven on the pin indicated in parenthesis below the signal name.

Figure 4.17 Viterbi Decoder Output Waveforms



The L64704 outputs the decoded Viterbi data stream serially on pin CO0 one bit per OCLK cycle. The V\_DVALIDOUT signal indicates whether data on CO0 is valid on a cycle-by-cycle basis. The  $V_BITERR$  signal carries information on errors found in the Viterbi output bit stream. If the L64704 deasserts  $V_BITERR$ , it indicates that the decoder has not correctly decoded the current data on V\_CO.

4.5.7 You can observe the outputs of the Viterbi synchronization stage and the associated depuncturing module by setting the OS[2:0] bits to 0b110.
Depuncture/ Figure 4.18 shows the waveforms for the Viterbi Synchroniza-tion/Depuncture module output signals. Signals prefixed by "DP\_" are driven on the pin indicated in parenthesis below the signal name.

Figure 4.18 Viterbi Depuncture/ Synchronization Output Waveforms



In this mode, the L64704 outputs the depunctured Viterbi input data stream. The data stream consists of two symbol streams and two corresponding erasures flags on the CO[7:0] bus as shown in Figure 4.18. The L64704 uses the S1\_INSYNC signal to monitor the state of the Viterbi synchronization stage. When the L64704 asserts S1\_INSYNC, it indicates that Viterbi module synchronization has been established. When the L64704 deasserts S1\_INSYNC, it indicates an out-of-sync condition.

# 4.5.8 QPSK Demodulator Output

You can observe the outputs of the QPSK Demodulator module by setting the OS[2:0] bits to 0b111. Signals prefixed by "DEMOD\_" are driven on the pin indicated in parenthesis below the signal name. Figure 4.19 shows the waveforms for the QPSK Demodulator module output signals.



In this mode, the L64704 outputs the demodulated QPSK data stream. This data stream consists of two symbol streams DEMOD\_I and DEMOD\_Q accompanied by DEMOD\_DVALID.

# Chapter 5 Demodulator Module Functional Description

This chapter describes the function of the BPSK/QPSK Demodulator module within the L64704 and is divided into the following sections:

- Section 5.1, "Overview," provides a high-level description of the Demodulator Module and shows how it fits into a set-top decoder.
- Section 5.2, "DC Offset Compensation and Coupling to ADC Output," describes the L64704's DC Offset Compensation circuit.
- Section 5.3, "Decimation Filters," describes the two input decimation filters.
- Section 5.4, "Matched Filter," provides information on the I and Q branch decimation filter.
- Section 5.5, "Channel Clock Recovery," provides information on the Channel Clock recovery loop.
- Section 5.6, "Carrier Synchronizer," describes the logic that is necessary to implement the Carrier Synchronizer circuit.
- Section 5.7, "Automatic Gain Control (AGC)," describes the L64704's automatic gain control.
- Section 5.8, "Output Control," provides information on the QPSK demodulator's output control circuitry.
- Section 5.9, "Other Functions," describes all of the remaining circuitry in the L64704's BPSK/QPSK Demodulator.

 5.1
 The Demodulator Module connects to the satellite receiver circuitry in the set-top box to recover the modulated MPEG-2 transport stream.

 Figure 5.1 shows the connections between the BPSK/QPSK Demodulator and its associated circuitry.

### Figure 5.1 Demodulator Module and its Associated Circuitry



The L64704 provides for an internal suppression of DC offsets on the I DC Offset and Q channels. To enable this function, set the PWR\_BW bits (Group 4, Compensation APR 20). This feature is particularly useful when using an integrated and Coupling to front end that does not provide DC offset compensation pins and that ADC Output introduces small offsets.

> The external analog to digital convertor must produce six-bit samples that reflect the 32-positive values and 32-negative values as shown in Figure 5.2. The six-bit samples are fed to the RI[5:0] and RQ[5:0] inputs.



5.2

5.3 The L64704 implements two switchable decimation filters on each I and Decimation Q branch: a 1/2-band filter and a 2/3-band filter. These two filters enable the Analog to Digital Convertor (ADC) to operate at an oversampling ratio Filters of N = 2, 3, or 4. The filters generate 2/T-sampled I and Q streams from the 3/T or 4/T sampled I and Q inputs. The resulting 2/T streams are inputs for the matched filter.

> To configure the decimation filters, the microcontroller should write one of the following values to the CLK DR[1:0] bits of the Clock Loop Control 1 register (Group 4, APR14):

- $CLK_DR = 0$  for no decimation, N = 2
- CLK\_DR = 1 for decimation by 1/2, N = 4
- CLK DR = 2 for decimation by 2/3, N = 3

#### 5.4 The L64704 implements a fixed matched filter on the I and Q branches Matched Filter according to the DVB standard (square root raised cosine shape with rolloff B = 0.35). The filter operates at a constant input rate of 2/T.

Figure 5.3 illustrates the Channel Clock recovery loop. This circuit con-**Channel Clock** sists of the L64704's Clock Synchronizer and external analog circuitry. Recovery The Clock Synchronizer generates the loop voltage for an external VCO from the L64704's matched-filtered I and Q samples. The Clock Synchronizer delivers this voltage to the two balanced CMOS differential output pins CLK\_VCON and CLK\_VCOP. These outputs feed the inverting and noninverting inputs of an external operational amplifier that implements the loop filter before the VCO.



5.5



5.5.1The CLK\_RATIO[2:0] bits (Group 4, APR 18) set the ratio of the VCO<br/>clock to the required sample clock in the L64704. For example, if the<br/>input signal is 5-Mbaud and the oversampling ratio is N = 4, then the<br/>input sample frequency is 20 MHz. Under the same conditions, it is pos-<br/>sible to use a VCO running at 40 MHz by specifying CLK\_RATIO = 1.<br/>This corresponds to an input decimation of 2, and in this case every<br/>second sample coming from the ADC is fed to the L64704.

This feature allows the satellite decoder control program to choose a reduced VCO range when the L64704 must operate over a wide range of baud rates. Note that setting the CLK\_RATIO bits does not switch any decimation filters in the data path; therefore the external IF SAW filtering must fit the baud rate and the oversampling ratio selected via the CLK\_DR bits (Group 4, APR 14).

The Clock Synchronizer operates in two modes:

Clock Acquisition and Tracking Modes

5.5.2

- Clock Acquisition
- Tracking

#### 5.5.2.1 Clock Acquisition Mode

In the acquisition mode (indicated by CLK\_LCF = 0; Group 3, APR 9), the Automatic Frequency Controller (AFC) is active but the Timing Error Detector (TED) is not. Software can disable the AFC after the Clock Synchronizer completes acquisition of the timing loop. This prevents the system from switching back to acquisition mode if a short interrupt occurs during transmission. Setting the CLK\_LCF\_SUPPRESS bit (Group 4, APR 14) disables the AFC.

The AFC control function determines whether the VCO clock is within the pull-in range of the L64704. If the VCO clock is within the pull-in range, the CLK\_LCF bit is set to 1. If the VCO clock is too slow, then the AFC drives a positive voltage on the loop output in order to generate a positive frequency sweep. If the VCO clock is too fast, then the AFC drives a low voltage on the loop output in order to generate a negative frequency sweep.

A counter in the AFC decrements once for each VCO clock edge during the reference period defined below. The microcontroller sets the counter's initial value using the 16-bit CLK\_NF register (Group 4, APR 16:17). If the counter has reached either -2, -1, 0, 1, or 2 at the end of the reference period, the VCO clock is within the pull-in range; therefore the AFC sets the CLK\_LCF bit to 1 to declare a lock. If the counter value is greater than 3, the VCO clock frequency is too low; therefore the AFC drives a positive voltage on the loop output in order to generate a positive frequency sweep. If the counter value is less than -3, the VCO clock frequency is too high; therefore the AFC drives a low voltage on the loop output in order to generate a negative frequency sweep.

The reference period is determined by the frequency reference from an external crystal. The reference period is derived by preloading a reference counter with the value in the CLK\_RP register (Group 4, APR 15). This defines the reference period in multiples of 1024 clock cycles. CLK\_RP is a 4-bit register, whose value ranges from 0 to 15.

The external crystal frequency  $f_{XO}$  must be less than half the VCO clock frequency  $f_{VCO}$ . The recommended value of  $f_{XO}$  is 10 MHz and the uncertainty in AFC is:

 $\frac{\pm 2 f_{XO}}{(1024 \times \text{CLK}\_\text{RP})}$ 

To ensure that the clock recovery loop locks when the Clock Synchronizer switches from acquisition to tracking mode, the uncertainty in AFC must be lower than the pull-in range of the clock recovery loop.

For CLK\_RP = 10 and  $f_{XO}$  = 10 MHz, the uncertainty is approximately ±2 kHz. Equation 5.1 relates the parameters described above and must be satisfied for reliable operation.

Equation 5.1  $f_{VCO} \times (CLK\_RP \times 1024) = f_{XO} \times CLK\_NF$ 

For example, consider the following frequency values:

- Nominal VCO clock frequency, f<sub>VCO</sub> = 60 MHz
- External crystal frequency, f<sub>XO</sub> = 10 MHz

According to Equation 5.1, CLK\_RP and CLK\_NF must be set such that:

Equation 5.2  $60 \times (CLK\_RP \times 1024) = 10 \times CLK\_NF$ 

For instance, if you choose  $CLK_RP = 10 = 0xA$ , then  $CLK_NF = 6 \times 10 \times 1024 = 61440 = 0xF000$ .

When the VCO clock frequency is within the pull-in range, the Clock Synchronizer closes the clock recovery loop automatically and then enters tracking mode.

#### 5.5.2.2 Tracking Mode

In tracking mode (indicated by CLK\_LCF; Group 3, APR 9 = 1), the clock recovery loop is closed and the Sigma Delta ( $\Sigma\Delta$ ) converter takes its input from the Timing Error Detector (TED) output rather than the AFC output.

The loop characteristics are determined by the external active filter with parameters  $R_{CLK1}$ ,  $R_{CLK2}$ ,  $C_{CLK}$ , and the VCO gain  $K_{VCO}$ .

The natural frequency  $\omega_n$  and the damping factor  $\zeta$  of the loop are determined by the following formulas:

Equation 5.3

$$R_{CLK2}C_{CLK} = \frac{2\zeta}{\omega_n}$$

Equation 5.4

$$\mathsf{R}_{CLK1}C_{CLK} = \frac{1}{\omega_n^2} \times \frac{K_D K_{VCC}}{2\pi M}$$

where *M* denotes the number of samples per symbol at the ADC and is at least 2,  $K_D$  is a constant equal to 1.4 volts, and  $K_{VCO}$  is expressed in rad/s/volt. Table 5.1 illustrates how *M* depends on the value of CLK\_DR (Group 4, APR 14) and CLK\_RATIO (Group 4, APR 18).

| Table 5.1<br>M as a Function of | CLK_DR[1:0] | М                          |
|---------------------------------|-------------|----------------------------|
| CLK_DR and<br>CLK RATIO         | 0           | 2 x 2 <sup>CLK_RATIO</sup> |
|                                 | 1           | 4 x 2 <sup>CLK_RATIO</sup> |
|                                 | 2           | 3 x 2 <sup>CLK_RATIO</sup> |

Choose the natural frequency  $\omega_n$  according to Table 5.2. For fixed rate operation, set the damping factor  $\zeta$  to one.

| Table 5.2<br>Natural Frequency<br>as a Function of M | Samples per<br>Symbol, M                                                                                                                                                                                           | Frequency,<br>ω <sub>n</sub> (rad/s)                                                                                                                                                                           |            |  |
|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--|
|                                                      | 2                                                                                                                                                                                                                  | 3900                                                                                                                                                                                                           |            |  |
|                                                      | 3                                                                                                                                                                                                                  | 3178                                                                                                                                                                                                           |            |  |
|                                                      | 4                                                                                                                                                                                                                  | 2752                                                                                                                                                                                                           |            |  |
|                                                      | 8                                                                                                                                                                                                                  | 1950                                                                                                                                                                                                           |            |  |
|                                                      | For variable rate operation, set $\zeta$ to one for the highest oversampling. $\omega_n$ decreases for higher oversampling, which corresponds to lower symbol rates.                                               |                                                                                                                                                                                                                |            |  |
| 5.5.3<br>Output Symbol<br>Clock                      | the demodula<br>Figure 4.2).                                                                                                                                                                                       | erates an internal symbol clock SCLK, that is used<br>ated symbols DEMI and DEMQ (see Figure 4.1 an<br>this clock can also be brought out on the PCLK pin<br>LL to generate a clock for the decoding pipeline. | d          |  |
| 5.5.4<br>Constraints on                              |                                                                                                                                                                                                                    | input samples may be 2x, 3x, or 4x oversampled, mpling rate of 62.5 Msamples/second.                                                                                                                           | with a     |  |
| Data Rates                                           | For a given IF SAW filter characteristic and a given oversampling factor N, the range of achievable data rates is limited by two constraints. These constraints are described below and illustrated in Figure 5.4. |                                                                                                                                                                                                                |            |  |
|                                                      | function-                                                                                                                                                                                                          | al spectrum must not be distorted by the IF filterin-<br>-that is, the maximum signal frequency must lie wi<br>dwidth (2b <sub>1</sub> ) of the IF SAW filter, as shown in the f                               | thin the - |  |
| Equation 5.5                                         | $\frac{(1+\beta)}{2T} \leq$                                                                                                                                                                                        | b <sub>1</sub>                                                                                                                                                                                                 |            |  |
|                                                      | where b<br>symbol c                                                                                                                                                                                                | s the matched filter roll-off and T is the QPSK (or<br>uration.                                                                                                                                                | BPSK)      |  |

Figure 5.4 Spectrum of Oversampled Signal



| Table 5.3<br>Example of Data | Oversampling | Baud Rate | Data Rate, R (Mbit/s) |       |       |
|------------------------------|--------------|-----------|-----------------------|-------|-------|
| Rates                        | Factor, N    | Min       | Max                   | Min   | Max   |
|                              | 2            | 17.96     | 24.07                 | 35.92 | 48.15 |
|                              | 3            | 10.23     | 20.67                 | 20.46 | 41.32 |
|                              | 4            | 7.15      | 15.5                  | 14.3  | 31    |

1. The minimum and maximum baud rates delimit an inclusive range.

Table 5.4 shows the achievable data rate ranges for a narrower off-theshelf IF SAW filter with  $b_1 = 11.9$  MHz,  $b_2 = 16.25$  MHz, and  $\beta = 0.35$ .

| Table 5.4<br>Example of Data   | Oversampling Baud Rate <sup>1</sup> , 1/T (Mbaud) Data Rate, R (Mbit/s) |       |       |       |       |
|--------------------------------|-------------------------------------------------------------------------|-------|-------|-------|-------|
| Rates for Narrow<br>SAW Filter | Factor, N                                                               | Min   | Max   | Min   | Max   |
|                                | 2                                                                       | 12.26 | 17.63 | 24.52 | 35.25 |
|                                | 3                                                                       | 6.99  | 17.63 | 13.98 | 35.26 |
|                                | 4                                                                       | 4.89  | 15.55 | 9.77  | 31.1  |

1. The minimum and maximum baud rates delimit an inclusive range.

#### 5.6 Carrier

Figure 5.5 illustrates the Carrier Synchronizer. This circuit consists of the following functional elements:

#### Synchronizer

- A phase error detector
- A digital loop filter
- A phase lock detector
- A frequency sweep generator
- A frequency lock detector

Figure 5.5 Carrier Recovery Loop



Because the outputs of off-the-shelf tuners for DVB satellite receivers have a large frequency uncertainty (a common order of magnitude is  $\pm 5$  MHz), the L64704's Carrier Synchronizer includes a frequency sweep generator for signal acquisition.

To minimize the complexity of external analog circuitry for the loop filter, the L64704 implements part of the loop filter digitally. The external part of the loop filter consists of only fixed components. You can choose values for these components that cover a whole range of data rates.

The Carrier Synchronizer provides its output to the analog filter through two  $\Sigma\Delta$  differential pairs; CAR\_VCO1P/N and CAR\_VCO2P/N. Depending on the value of the CAR\_VCO1N/P and CAR\_VCO2N/P bits (Group 4, APR 33), the Carrier Synchronizer selects one pair and 3-states the other pair. An analog integrator adds the signals together externally, where the signals of pair 2 are weighted with a different factor relative to the signals of pair 1. You choose different values for R<sub>CAR1</sub> and R<sub>CAR2</sub> to change the weighting factor (see Section 5.6.2.2, "Loop Characteristics"). This feature provides a means for adjusting the loop bandwidth over a larger range than would be possible with pure  $\Sigma\Delta$  modulation.

#### 5.6.1 Carrier Acquisition

During carrier acquisition, the internal frequency sweep generator searches for the correct frequency. To vary the sweep rate, change the value in the CAR\_SWR register (Group 4, APR 28); to start the sweep generator, set the CAR\_SW bit (Group 4, APR 33) to 1.

#### 5.6.1.1 Frequency Sweep Limits

The CAR\_USWL (Group 4, APR 29:30) and CAR\_LSWL (Group 4, APR 31:32) registers set the upper and lower limits, respectively, of the frequency sweep.

The frequency sweep uses an external crystal that produces a reference clock (the same crystal as for clock acquisition). See Appendix C, "Oscillator Cells" for details.

The external prescaler divides the frequency of the carrier VCO by a constant number (32, for example) and then feeds it into the L64704 on the CAR\_DCLK pair of differential input pins. You should design the prescaler so that the frequency is faster than the crystal reference frequency and slower than 80% of the CLK frequency.

The reference period for the VCO frequency measurement ends when a decrementing reference counter driven by the reference clock reaches zero. The L64704 loads the counter with the value in the 4-bit CAR\_RP register (Group 4, APR 24). This value defines the reference period in multiples of 1024 clock cycles.

The prescaled clock drives an incrementing counter within the VCOF block that is reset at the beginning of the reference period. The VCOF logic then checks the value of the counter at the end of the reference period. If the prescaled frequency is below the lower limit set in the

CAR\_LWSL register (Group 4, APR 31:32), the VCOF block automatically tells the sweep generator to increase the VCO frequency. If the prescaled frequency is above the upper limit set in the CAR\_USWL register, the VCOF block tells the sweep generator to decrease the VCO frequency. Figure 5.6 illustrates how the sweep generator keeps the VCO frequency within the established limits.





For example, consider the following frequency values:

- VCO nominal frequency = 480 MHz
- Frequency uncertainty = ±3 MHz
- prescaling ratio = 32

With these values, the lower prescaled frequency is (480 - 3)/32 = 14.90625 MHz, and the upper prescaled frequency is (480 + 3)/32 = 15.09375 MHz.

If the CAR\_RP register is set to 8, the reference period is 8192 reference clock cycles (for instance, at 10 MHz), and the upper and lower sweep limits must have the following values:

CAR\_LSWL = 
$$14.90625 \times \frac{8192}{10} = 12,211$$
 (lower limit)  
CAR\_USWL =  $15.09375 \times \frac{8192}{10} = 12,365$  (upper limit)

#### 5.6.1.2 Carrier VCO Frequency Measurement

The L64704 puts the result of the VCO frequency measurement into the 16-bit CAR\_VCOF register (Group 3, APR 6:7) for the microcontroller to read. You must read both nibbles before the L64704 releases this register for a new value.

The L64704 computes the value that it puts into the CAR\_VCOF register based on Equation 5.8.

Equation 5.8 
$$CAR_VCOF \times f_{xo} = CAR_RP \times 1024 \times \frac{f_{CAR_VCO}}{prescaler}$$

For example, if  $f_{xo}$  = 10 MHz, CAR\_RP = 8,  $f_{CAR_VCO}$  = 480 MHz, and prescaler = 32, then

$$CAR_VCOF = \frac{f_{CAR_VCO} \times CAR_RP \times 1024}{f_{xo}} = \frac{480 \times 8 \times 1024}{10 \times 32} = 12288$$

So that the value each bit in the CAR\_VCOF register is given by the following:

$$\frac{f_{CAR_VCO}}{CAR_VCOF} = \frac{480 \times 10^6}{12288} = 39062 \text{ Hz}$$

Therefore if prescaler = 16, then the value for each bit in the CAR\_VCOF register is 14.5 kHz.

#### 5.6.1.3 Frequency Sweep Without Prescaled Frequency Signal

The frequency sweep generator can also operate without using the prescaled frequency. This can be very convenient if the analog front end does not provide for a prescaler function.

In this case, both the CAR\_USWL (Group 4, APR 29:30) and CAR\_LSWL (Group 4, APR 31:32) registers must be set to zero. The state of the CAR\_SWP\_SWP (Group 4, APR 33) bit controls the sweep direction. Even though the Carrier Synchronizer controls the frequency sweep rate based on the value in the CAR\_SWR register (Group 4, APR 28), the microcontroller must monitor the sweep direction itself.

#### 5.6.1.4 Frequency Sweep Rate

The Carrier Synchronizer determines the frequency sweep rate based on the value in the CAR\_SWR register. Set the value in the 8-bit CAR\_SWR register based on Equation 5.9.

Equation 5.9  $CAR_SWR = 64K_D\theta_{\infty}$ 

 $K_D$  is the gain of the carrier phase error detector. Assuming a standard power reference value (the value in the PWR\_REF register, Group 4, APR 19, is 84),  $K_D$  has a typical value of 10 for low Eb/No conditions (4 dB) for both the DDML and the NDAML phase error detectors (see Section 5.6.2, "Carrier Phase Tracking"). For larger Eb/No conditions (10 dB),  $K_D$  is around 26 for the DDML and around 42 for the NDAML.

 $K_D$  grows linearly with  $\sqrt{PWR\_REF}$ .  $\theta_{\infty}$  is the phase loop steady state error during acquisition. It should always remain lower than 5 degrees. During the tracking phase, the loop drives the residual steady state error to 0.

Equation 5.10 gives the sweep rate in Hertz per second.

Equation 5.10 
$$\dot{f} = CAR_SWR \cdot \frac{3.3}{128\pi} \cdot \frac{K_{VCO}}{R_{CAR}C_{CAR}(CAR_KP)}$$

For example, if  $K_D = 10$  and  $\theta_{\infty} = 3^\circ = 0.052$  rad, then CAR\_SWR = 33. Assuming the analog components verify Equation 5.11, and CAR\_KP (Group 4, APR 25) = 50, we get df/dt = 32.6 MHz per second.

#### 5.6.1.5 Phase Lock Detection

Once the VCO frequency is close enough to the frequency of the incoming wave, the signal lies in the pull-in range of the phase-locked loop. When the loop is phase locked, the phase lock detector sets the CAR\_LC bit (Group 3, APR 9) to 1. To stop the sweep, the microcontroller must then set the CAR\_SW bit (Group 4, APR 33) to zero.

The phase lock detector uses an internal threshold and an estimation period, which are programmable using the CAR\_THSL register (Group 4, APR 27) and the CAR\_OUT\_SEL bit (Group 4, APR 33), respectively.

The CAR\_OUT\_SEL bit selects between a long and a short estimation period. For operation at low Eb/No (less than 10 dB), the long period should be selected (CAR\_OUT\_SEL = 0). A typical value of CAR\_THSL is then 31.

For operation at higher Eb/No (10 dB or higher), the short period can be selected. This provides for a faster lock detection. In this case, a typical value for CAR\_THSL is 72.

#### 5.6.1.6 Frequency Lock Detection

The frequency lock detector also has a configurable estimation period, selectable by the same parameter as for phase lock detection (the CAR\_OUT\_SEL bit). No threshold values have to be programmed for the frequency lock detector; the thresholds are fixed and hard-coded in the L64704.

#### 5.6.1.7 False Locks

The microcontroller must take particular care to handle a false lock condition correctly. A false lock occurs when phase lock has been detected but the correct central frequency has not been reached yet. This situation happens in QPSK for frequency offsets that are multiples of 1/4T, where T is the QPSK symbol duration.

This case is detected by CAR\_LC = 1 and CAR\_LCF = 0 (both bits are in Group 3, APR 9). When the microcontroller detects this situation, it should set the CAR\_OPEN (Group 4, APR 33) bit to 1 and reset it after CAR\_LC = 0. This has the effect of opening the carrier loop, forcing the loop to run out of the false lock point.

#### 5.6.2.1 Phase Error Estimator

5.6.2 Carrier Phase Tracking

In QPSK mode (CON\_SEL = 0; Group 4, APR 35), the phase error detector implements two error estimators:

- a Non-data Aided Maximum Likelihood (NDAML) estimator
- a Decision Directed Maximum Likelihood (DDML) estimator

The microcontroller selects the estimator via the CAR\_PED\_SEL bit (Group 4, APR 33). CAR\_PED\_SEL = 0 sets the DDML estimator; CAR\_PED\_SEL = 1 sets the NDAML estimator.

In BPSK mode (CON\_SEL = 1), the phase error detector implements a single DDML estimator.

The phase detector uses two gain values depending on the signal to noise ratio. The SNR is internally estimated and compared to an 8-bit threshold; SNR\_THS (Group 4, APR 22). The plot in Figure 5.7 shows the relation between the SNR\_THS parameter and the actual Es/No (symbol energy to noise power density) seen in the circuit. The value SNR\_THS = 100 corresponding to an actual Es/No = 11 dB is recommended. The result of the comparison of the estimated SNR to the threshold is stored in the Demod\_SNR bit (Group 3, APR 6, bit 7).





#### 5.6.2.2 Loop Characteristics

To set the parameters of the carrier recovery loop (natural frequency and damping factor), you must select both the values the microcontroller writes into the registers CAR\_KD (Group 4, APR 26) and CAR\_KP (Group 4, APR 25), and the values of the resistors and capacitors of the external active filter (shown in Figure 5.8).





The natural frequency  $\omega_n$  (rad/s) and the damping factor  $\zeta$  of the loop are determined by the following equations.

Equation 5.11 
$$\zeta = 2 \cdot CAR\_KD \cdot \omega_n \cdot T , \ \omega_n = \sqrt{\frac{3.3K_DK_{CARVCO}}{R_{CAR}C_{CAR}(CAR\_KP)}}$$

 $K_D$  is the Phase Detector Gain and it depends on whether DDML or NDAML is selected. Figure 5.9 presents the gains of the two phase detectors as a function of the Carrier to Noise ratio (C/N).



 $K_D$  is about 10 for C/N = 4 dB (Channel Es/No = 1 dB).

Set  $K_D$  = 10,  $K_{CARVCO}$  = 1.8 MHz/V = 11.3 Mrad/s/V and  $\omega_n$  = 32K rad/s/v.

*T* represents the QPSK symbol duration. Twice the value of the parameter CAR\_KP determines the resolution of the  $\Sigma\Delta$  conversion; it should be kept above 30 and below 127 for 6 bits of resolution.

The loop filter output is provided with two  $\Sigma\Delta$  modulated complementary signal pairs, CAR\_VCO1P and CAR\_VCO1N, and AR\_VCO2P and CAR\_VCO2N. These signals connect to the external active integrator, that completes the loop filter chain (Figure 5.8). One of the complementary pairs is selected while the other is 3-stated, depending on the settings of the CAR\_VCO1N/P and CAR\_VCO2N/P bits (Group 4, APR 33). After reset, both complementary pairs are active. Externally, these signals are added together in the analog integrator. The CAR\_VCO2P/N outputs should be weighted with a different factor with respect to the CAR\_VCO1P/N outputs by proper selection of the corresponding resistors and capacitors. With two pairs of loop-filter outputs, you can adjust the loop bandwidth over a large range of data rates by enabling one or the other of the output pairs.

#### 5.6.2.3 Low Baud Rate Operation

For low-baud-rate operation (between one and five Mbaud), the Sigma-Delta conversion used in the carrier loop introduces a delay that makes the carrier loop too narrow for reliable operation.

For this type of application, program the CAR\_OUT\_SEL bit (Group 4, APR 33) so that the L64704 Carrier Loop pins carry the Phase Error Detector to DAC (CAR\_PED[5:0]) outputs instead of the CAR\_VCOxP/N outputs. The CAR\_PED signal is simply the digital signal before Sigma-Delta conversion. It is intended to be connected to an external 6-bit DAC, that then feeds a similar active low-pass filter as described previously. You program the L64704 to output the SCLK signal on the DVALIDOUT pin by setting the SYNC/SCLK bit (Group 4, APR 14) to 1. The SCLK signal on the DVALIDOUT pin is used to clock the external DAC.

You should set the CAR\_PED\_SEL bit to 1 to enable the CAR\_PED[5:0] outputs. You also need to feed the voltage level from the DAC's output to a loop filter similar to one of the filters shown in Figure 5.10.

For low bit rate applications that use an external DAC, you must enable both Sigma-Delta outputs by setting Carrier Loop Configuration Register (Group 4, APR 33) bits [5:4] to zero.

The output of the DAC interface, CAR\_PED[5:0] is in offset binary format. A value of '000000' produces a decrease in the VCO control voltage. A value of '111111' produces an increase in the VCO control voltage. The value '100000' is the zero control voltage.

Figure 5.10 Using CAR\_PED Outputs



- 1. Choose CAR\_KD as described in Section 5.6.1.4, "Frequency Sweep Rate."
- 2. Choose  $\zeta$  (see Equation 5.11).
- 3. Choose  $\omega_n$  (see Equation 5.11).
- 4. Calculate R<sub>2</sub>, R<sub>1</sub>, and C from the following equations:

$$\frac{R_2 \cdot C \cdot \omega_n}{2} , \omega_n = \sqrt{\frac{K_D K_{carvco} (CAR_KD) ADR}{R_1 C \times 8192}}$$

ADR is one side of the DAC range. For example, if the DAC output range is  $\pm 1$  volt, then ADR = one.

5.7 This section describes the L64704's automatic gain control (AGC) and is divided into the following subsections:Control (AGC)

- Section 5.7.1, "ADC Range and Power Reference"
- Section 5.7.2, "Power Control Loop"
- Section 5.7.3, "Power Level"

#### 5.7.1 ADC Range and Power Reference

Figure 5.11

Eye Pattern and ADC Range

When the PWR\_REF register (Group 4, APR 19) is set to the recommended value of 84, the AGC sets the ratio of the signal range to the Analog-to-Digital Convertor (ADC) range to 1:1.7 (see Figure 5.11).



Assuming that the signal power at the input of the ADC is normalized to  $1 V^2$ , the range of the signal (2S) is 2 V (the noise-free level of the I and Q signals). The value of PWR\_REF is computed from Equation 5.12.

Equation 5.12

 $PWR\_REF = \frac{243 \cdot L}{R^2}$ 

where L = 1 if CLK\_DR (Group 4, APR 14) = 0 (no internal decimation filter is used), or L = 4 if CLK\_DR = 1 or 2. *R* is the ADC range. For L = 1

and a unit signal level, a recommended value for *R* is 1.7, which corresponds to PWR\_REF = 84. For L = 4, a recommended value for *R* is 3.4, which also corresponds to PWR\_REF = 84.

The ratio of the signal level to the ADC range is constant (S:R = 1:1.7) in Figure 5.11. If the ADC range changes, the AGC scales the signal level to keep the S:R ratio constant.

5.7.2The L64704 measures the signal power at the output of the matchedPower Controlfilter and compares the measured value to an expected value that the<br/>microcontroller has written into the PWR\_REF register.

The microcontroller can adjust the power loop bandwidth using the PWR\_BW[1:0] bits (Group 4, APR 20). The loop bandwidth is proportional to PWR\_BW and proportional to the symbol rate. Set the PWR\_BW bits according to Table 5.5.

| Table 5.5<br>PWR_BW as a   | PWR_BW | Symbol Rate (MHz) |
|----------------------------|--------|-------------------|
| Function of Symbol<br>Rate | 0      | 20 - 45           |
|                            | 1      | 10 - 20           |
|                            | 2      | 5 - 10            |
|                            | 3      | 2 - 5             |

The power control signal drives the  $\Sigma\Delta$  modulated output PWRP. You use this output to drive an external passive RC filter that feeds the gain control stage (Figure 5.12).





The *R* and *C* values for the passive low-pass filter should be such that  $R_{AGC}C_{AGC} \cong 64 \ \mu s$ .

**5.7.3** The L64704 stores the AGC loop control voltage in the PWR\_LVL[7:0] register (Group 3, APR 8), where the microcontroller can monitor it. The relation between the loop voltage  $V_{AGC}$  and the PWR\_LVL register is:

$$V_{AGC} = \frac{PWR\_LVL}{256} \times V_{REF}$$

The PWRP pin uses an open drain buffer that allows you to apply an external  $V_{REF}$  voltage of 5 V even if the L64704 is powered at 3.3 V.

## **5.8** Because the output of the matched filter is quantized to three bits for the subsequent Viterbi decoder, the L64704's Output Control properly adjusts the level of the output signals.

The microcontroller can adjust the level of the demodulated DEMI and DEMQ output signals using the SCALE register (Group 4, APR 21). The SCALE register multiplies the results of the matched filter before it is truncated to the 3-bit outputs.

When the PWR\_REF register (Group 4, APR 19) is set to its recommended value of 84, SCALE[7:0] should be set to 158. In this case, the spacing for the 3-bit quantized outputs DEMI and DEMQ is equal to a/8, where a is the eye amplitude of the noise free matched filter output. Refer to Figure 5.13.

SCALE[7:0]should be set according to the following table:

| Vite | rbi Ra | Scale |     |
|------|--------|-------|-----|
| 1/2  | 2/3    | 3/4   | 158 |
|      | 5/6    | 7/8   | 190 |

Figure 5.13 Eye Pattern and Soft Decision Thresholds



The useful part of the matched filter output signal is clipped for a larger value of SCALE.

Because the power control loop automatically reduces the eye amplitude for increasing noise, the DEMI and DEMQ signals include additional headroom for resolving noise.

Equation 5.13 relates SCALE and PWR\_REF.

Equation 5.13 SCALE  $\times \sqrt{2 \times PWR\_REF} = 2047$ 

**5.9** The following functions have been added in order to simplify the design of the analog front end, to reduce the amount of external circuitry, and to make the board layout as simple as possible.

5.9.1 Carrier Loop DC Offset Compensation

As discussed in previous sections, filtering in the carrier loop is carried out in the analog domain. Because of the imperfections of analog components, the loop voltage could show a DC offset. This would have two consequences:

- During the acquisition phase, the frequency sweep becomes asymmetric. The DC offset slows down the sweep in one direction and makes it faster in the other direction. If the sweep is too slow, false locks can occur at high SNR. If the sweep is too fast, locks can be missed at low SNR.
- During the tracking phase, the static error of the loop is not minimum. This is because the DC offset generates a frequency ramp that the loop has to compensate for.

For these reasons, the L64704 implements an internal offset compensation in the carrier loop. This internal compensation operates in two modes: acquisition and tracking.

#### 5.9.1.1 Carrier Acquisition Phase

In the acquisition phase, the L64704 reads the DC offset estimation from the CAR\_OFFSET[7:0] register (Group 4, APR 15) and subtracts it from the loop voltage. The CAR\_OFFSET register is assumed to have been previously loaded by the microcontroller. The CAR\_OFFSET parameter is a signed integer ranging from -128 to +127.

- T<sub>up</sub> can be measured by using an oscilloscope.
- ♦ If T<sub>up</sub> is the ramp-up time and T<sub>dwn</sub> the ramp-down time (with CAR\_OFFSET = 0 and CAR\_OPEN = 1, open loop), then the CAR\_OFFSET value can be computed by the following formula:

Equation 5.14 
$$CAR_OFFSET = \pm \frac{CAR_SWR_T_{dwn} - T_{up}}{2} T_{dwn} + T_{up}$$

The  $\pm$  choice depends on the polarity of the N/P outputs. Select + if polarity is normal; select - if it is swapped.

#### 5.9.1.2 Carrier Tracking Phase

In the tracking phase, the mean value of the phase error should be zero. The mean value is internally computed and subtracted from the phase error before Sigma-Delta conversion. This estimation and subtraction system is only enabled in tracking mode, that is, when CAR\_SW = 0.

The maximum offset voltage that can be compensated for by this mechanism is shown in Equation 5.15.

Equation 5.15 
$$V_{offmax} = \frac{CAR_OFFSET}{32} \frac{3.3V}{CAR_KP}$$

Note the following examples:

- ♦ for CAR\_KP = 255, V<sub>offmax</sub> = 51 mV (resolution 0.4 mV)
- ♦ for CAR\_KP = 30, V<sub>offmax</sub> = 436 mV (resolution 3.4 mV)

5.9.2 Five external control bits are available on the L64704. Four of these bits are output signals, and one is an input signal. These controls can be used to set up or to read parameters from other components on the board (like the RF front end and the tuner) using only the microcontroller interface of the L64704.

The four output controls use pins XCTR\_OUT.0, XCTR\_OUT.1, XCTR\_OUT.2, XCTR\_OUT.3. They are programmed by setting their respective bits in the XCTR[3:0] register (Group 4, APR 36). The XCTR[i] register drives the XCTR\_OUT.i pin; that is, programming the XCTR[i] register to 0 sets a 0 volt level on pin XCTR\_OUT.i, and programming the XCTR[i] register to 1 sets a 3.3 volt level on pin XCTR\_OUT.i.

The input control is sensed on the XCTR\_IN pin. The logic level applied to this pin is read using the XCTR\_IN bit (Group 3, APR 6).

| 5.9.3        | When F_OUT_HiZ is set to 1, all the functional outputs of the L64704 |
|--------------|----------------------------------------------------------------------|
| Hi-Z Mode on | are set to the high-impedance mode. These outputs include            |
| Functional   | CLK_VCON/P, CAR_VCOxN/P and PWRP.                                    |
| Outputs      |                                                                      |

### Chapter 6 Decoding Pipeline Synchronization

This chapter describes the configurable synchronization circuit that aligns the decoding pipeline outputs to the overall frame structure of the L64704. The decoding pipeline consists of the Viterbi Decoder, Deinterleaver, Reed-Solomon (RS) Decoder, and the Descrambler. This chapter consists of four sections:

- Section 6.1, "Synchronization Scheme," provides an overview of the Decoding Pipeline three stage synchronization process.
- Section 6.2, "Viterbi Decoder Synchronization," describes the synchronization module for the Viterbi Decoder.
- Section 6.3, "Reed-Solomon Deinterleaver Synchronization," shows the synchronization process for the Reed-Solomon Deinterleaver.
- Section 6.4, "Descrambler Synchronization," describes the synchronization module for the Descrambler module.

6.1The L64704's FEC synchronization scheme is composed of a threeSynchronizationstage synchronization process:

Scheme

- The first stage synchronization uses output statistics from the Viterbi Decoder module.
- The second stage identifies a synchronization word.
- The third stage identifies an inverting synchronization word.

A global control module generates the control signals for the Viterbi, Descrambler, Deinterleaver, and RS Decoder modules. The global control module handles the appropriate sequencing of the synchronization signals for determining in- and out-of-synchronization. The input to the FEC portion of the L64704 is two three-bit symbols generated by the demodulator portion. The maximum information rate is 62.5 Mbits/s. Figure 6.1 shows the position of and major connections to the synchronization module.

#### Synchronization Module **Configuration Parameters Global Control** DI In Svnc/ Viterbi In Svnc/ RS In Svnc/ Descrambler Control Out of Sync Control Out of Sync Control Out of Sync Control Signals Description Data Viterbi RS/DI Data Data Data Data Data Viterbi RS Data Sync Data Sync Deinterleaver Sync Description Decoder Decoder Module Module Module Bit Error Monitor

#### 6.2 Viterbi Decoder Synchronization

Figure 6.1

This section describes the first stage, or Viterbi Decoder synchronization. Figure 6.2 illustrates the Viterbi Decoder synchronization process.

In the first stage, the decoder observes the valid data symbols and bit errors in the decoded data stream to determine the in- or out-of-synchronization condition. The Viterbi Max Data Bit Count Registers (VMDC1; Group 4, APR 4, and VMDC2; Group 4, APR 5:7) set the number of valid data bits at the output of the Viterbi Decoder over which the decoder counts channel symbol errors. During that interval, whenever the bit error count is above the value specified in the Viterbi Max Data Bit Error Count Register (Group 4, APR 8), the synchronization logic flags an out-of-synchronization condition.

Figure 6.2 Viterbi Decoder Synchronization



The decoder then proceeds to adjust either the phase in the phase rotation module or the data stream alignment in the depuncturing logic by successively stepping through as many combinations as needed (and possibly all combinations) until synchronization is achieved. Because both I and Q channels can appear inverted and swapped, four phases are possible for the phase rotation block. Depending on the Viterbi code rate chosen, the depuncturing mechanism includes up to two states. (The 180 degree rotation is removed in the Reed-Solomon decoder synchronization stage. See page 6-10.) Figure 6.3 outlines the operations performed during phase rotation:



A misaligned data stream results in a difference in the bit error rate at the Viterbi Decoder output, compared to that of the original message, of about 0.5. The mechanism implemented provides strong correlation between an out-of-sync condition and the observed bit error rate.

This first synchronization stage does not inspect the data stream for specific synchronization patterns, nor does it remove any portions of the data stream. Once the Viterbi Decoder module has reached synchronization, the following blocks in the data pipeline (the Deinterleaver and Reed-Solomon Decoder) each require their own synchronization procedures.

# 6.3 This section describes the second synchronization stage; Reed-Solomon Deinterleaver synchronization. In the second synchronization stage, the decoder searches the data stream for a pre-defined sync word to determine the in-sync or out-of-sync condition. Figure 6.4 illustrates the Reed-Solomon Deinterleaver synchronization process.

Figure 6.4 Reed-Solomon, Deinterleaver Synchronization



**Configuration Parameters** 

Figure 6.5 shows an example state diagram that outlines how the decoder determines synchronization, tracking, and loss of synchronization in this stage.

Figure 6.5 Synchronization, Tracking, and Loss of Sync for 3 Missed Sync Words



Pa: State Transition, Sync Word Detected (N, M, K) Qa: State Transition, Sync Word Misdetected

Pt: State Transition, Sync Word Detected (N, M, L) Qt: State Transition, Sync Word Not Detected

The parameters in Figure 6.5 are defined as follows:

- **N** Length of the RS codeword in bytes
- M Length of synchronization word in bits (M = 8, fixed)
- **K** The maximum number of mismatching bits allowed to declare a match when comparing M bits in the data stream to the reference sync word during acquisition phase (K = 0, fixed)
- **MC** Match Counter, number of sync word matches found so far during acquisition phase
- L Maximum number of mismatching bits allowed to declare a match when comparing M bits in the data stream to the reference sync word during tracking phase (L = 0, 1, or 2)
- **MSC** Mismatch Counter, number of sync word mismatches found so far during tracking phase

You can configure some of the parameters in the state diagram for the acquisition and tracking phase. You can set the SSA parameter (Group 4, APR 11) to allow for three, four, five, or six sync words before the decoder declares itself to be in synchronization. You can also set the SST parameter (Group 4, APR 11) to allow for two, three, four, or five misdetected sync words before the decoder declares a loss of synchronization. Figure 6.6 and Figure 6.7 show the minimum and maximum number of states that you can select for acquisition and tracking modes.

#### Figure 6.6 Minimum and Maximum Number of States in the Acquisition Phase



Acquisition Phase (Maximum Number of States)





An MPEG-2 RS(204,188) protected transport packet consists of 204 bytes, including 1 sync byte, 187 data bytes, and 16 redundancy bytes. Figure 6.8 shows the data format of the MPEG-2 Transport Packet.



Table 6.1 shows the computed values for mean acquisition time  $(T_{ac})$ , mean time to loss of lock  $(T_{II})$ , and probability of false lock  $(P_{fI})$  for synchronization stage 2 as a function of the incoming bit error rate (code word length = 204 bytes, sync word length = 8 bits, K = 0, L = 2, 60 Mbits/s):

#### Table 6.1 Stage 2 Synchronization Values

|                | T <sub>ac</sub> |            | Т          | Тш         |            |
|----------------|-----------------|------------|------------|------------|------------|
| Bit Error Rate | # frames        | sec        | # frames   | sec        | sec        |
| 5.0e - 04      | 3.88            | 1.05e - 04 | 9.00e + 15 | 2.44e + 11 | 5.98e - 08 |
| 1.0e - 03      | 3.91            | 1.06e - 04 | 9.00e + 15 | 2.44e + 11 | 5.98e - 08 |
| 2.0e - 03      | 3.98            | 1.07e - 04 | 9.00e + 15 | 2.44e + 11 | 5.98e - 08 |
| 5.0e - 03      | 4.16            | 1.12e - 04 | 4.50e + 15 | 1.22e + 11 | 5.98e - 08 |
| 1.0e - 02      | 4.48            | 1.21e - 04 | 6.37e + 12 | 1.72e + 08 | 5.98e - 08 |
| 2.0e - 02      | 5.15            | 1.39e - 04 | 1.39e + 10 | 3.78e + 05 | 5.98e - 08 |
| 5.0e - 02      | 7.23            | 1.98e - 04 | 5.21e + 06 | 1.41e + 02 | 5.98e - 08 |

For an expected BER of 1.0e - 03, the decoder requires about four frame times to establish synchronization, and loss of sync occurs after 9.0e + 15 frames. With one modification, the DVB Standard of the European Broadcast Union has adopted this basic format as a standard for multiprogram TV via satellite. One out of every eight synchronization words in the data stream is mod 2 complemented. Figure 6.9 shows the data format of the L64704 transport packet.



Given a bit stream that consists of a sequence of these packets, the second synchronization stage searches for the predefined sync byte and, upon having met the synchronization acquisition criteria, issues the control strobes for the modules that follow.

In addition to providing the proper data alignment for the following Deinterleaver and Reed-Solomon Decoder modules, the second synchronization stage resolves the 180-degrees phase uncertainty that the upstream demodulator may have introduced. The first (Viterbi) synchronization stage is not able to detect this source of error. During the acquisition phase, the decoder simultaneously looks for the synchronization word and its complemented version to resolve the uncertainty.

The decoder does not remove the sync byte from the data stream because it is part of the MPEG system layer syntax, and therefore the channel decoding operation leaves it undisturbed.

6.4This section describes the third stage synchronization; Descrambler<br/>synchronization. Figure 6.10 illustrates the Descrambler synchronization<br/>process.

The L64704 restarts the Descrambler every 8 N byte times. The L64704 aligns this restart with the complemented synchronization word that is present in the data stream once every eight Reed-Solomon code words (once every 8 N bytes).



**Configuration Parameters** 

For this third stage synchronization, the L64704 uses an approach very similar to that used in the second synchronization stage during the acquisition phase to ensure proper data alignment. Because the detection of an out-of-synchronization condition in the second stage automatically

#### Figure 6.10 Descrambler Synchronization

forces the third stage to reacquire, the tracking phase for the third synchronization stage is simpler. Figure 6.11 shows a state diagram that outlines how the decoder determines synchronization, tracking, and loss of synchronization for the third stage.

Note that in this stage, any noninverting corrupted sync bytes found in the tracking phase are duly replaced by the original predefined noninverting sync byte.



Pa: State Transition, Inverting Sync Word Detected (8N, M, K) Qa: State Transition, Inverting Sync Word Misdetected

# Chapter 7 The FEC Decoder Pipeline

This chapter discusses the DEC Decoder Pipeline. The decoder pipeline consists of four modules that are connected in a logical sequence. This chapter discusses the four modules in the pipeline in five sections:

- Section 7.1, "Viterbi Decoder Module," provides details on the L64704's Viterbi Decoder module.
- Section 7.2, "Deinterleaver Module," describes the Deinterleaver module.
- Section 7.3, "Reed-Solomon Decoder," discusses the L64704's Reed-Solomon Decoder.
- Section 7.4, "Descrambler Module Architecture and Operation," provides details on the Descrambler module.
- Section 7.5, "FEC Module Software Reset" describes the use of the FEC\_Reset bit.

The Viterbi Decoder contains the following major modules:

Viterbi Decoder Module

7.1

- A depuncturing module for code rates other than 1/2
- A 1/2 code rate Viterbi decoder core that computes the serial output data stream given two sets of soft decision data input streams
- A synchronization monitoring block to provide information on acquisition or loss of synchronization
- A bit error rate monitoring block
- ♦ A control module

The block diagram in Figure 7.1 shows the relation of each of these modules to the other.

Figure 7.1 Block Diagram of Viterbi Decoder Core



7.1.1 Features The Viterbi decoder module has the following features:

- A Viterbi Decoding Core with a basic rate equal to 1/2
- Compliant with European Digital Video Broadcast (DVB) Association (V4/MOD-B) standards
- Depuncturing for code rates equal to 1/2, 2/3, 3/4, 5/6, and 7/8
- Accepts input in binary offset or sign magnitude format
- Constraint length (K) of seven
- Synchronization monitor
- Decoded Bit Error Rate (BER) monitor
- Maximal Likelihood (ML) decoding algorithm
- 5.2 dB coding gain for rate equal to 1/2 (no erased input) code at BER of 1e - 5
- Generating Polynomial 171 (Octal) and 133 (Octal)

7.1.2 The code performance for the Viterbi decoder is based on a simulation of a numerically accurate model of the architecture. Figure 7.2 shows the results for a constraint length (K) of seven and code rates of 1/2, 3/4 and 7/8 that were seen on a small sampling of Satellite Decoder Evaluation boards. Your results may be different.



 7.1.3 The L64704 supports not only the basic rate equal to 1/2 decoding operations, but also code rates equal to 2/3, 3/4, 5/6 and 7/8. The code rate and underlying depuncture scheme chosen dictates the proper sequence of symbols on the DEM\_I and DEM\_Q inputs. Table 7.1 shows the puncture patterns for various code rates. Table 7.1 Puncture Patterns for Various Code Rates

| Code Rate | Puncture Pattern |
|-----------|------------------|
| 1/2       | DEM_I: 1         |
|           | DEM_Q: 1         |
| 2/3       | DEM_I: 10        |
|           | DEM_Q: 1 1       |
| 3/4       | DEM_I: 101       |
|           | DEM_Q: 1 1 0     |
| 5/6       | DEM I: 10101     |
|           | DEM_Q: 1 1 0 1 0 |
| 7/8       | DEM_I: 1000101   |
|           | DEM_Q: 1111010   |

Figure 7.3 shows a block diagram of the puncturing and depuncturing process for a rate 1/2 encoder. For each data bit Dn, the upstream encoder generates two corresponding encoded data symbols, 1.n and Q.*n*. By deleting or *puncturing* some of the encoded data symbols, the puncturing process allows a rate 1/2 encoder to generate codes of higher rates. The L64704's depuncturing module allows its rate 1/2 decoder to decode data transmitted at higher code rates. Figure 7.4 illustrates the puncture patterns for different code rates.

Figure 7.3 Puncturing and Depuncturing Block Diagram



The L64704 receives the encoded data symbols in QPSK or BPSK format on the RI[5:0] and RQ[5:0] buses. The L64704 receives these symbols in the order shown on the right of L64704 Input Data in Figure 7.4. The depuncturing module handles the reordering and the insertion of erasures into the received symbol stream before the rate equal to 1/2 Viterbi decoder module starts decoding.



#### Figure 7.4 (Cont.) Puncture Pattern for Different Code Rates



Punctured Symbol (Deleted)

# 7.1.4 Viterbi Bit Error Rate Monitor

A performance monitor for the channel bit error rate (BER) is built into the L64704. The monitor compares an appropriately delayed version of the incoming channel data stream to the re-encoded Viterbi decoder output data stream to find occurrences of bit errors. Figure 7.5 shows a block diagram of the Viterbi bit error detection circuit.

The Viterbi decoder core latency delays depunctured data. The rate equal to 1/2 Viterbi decoder core produces a decoded bitstream that is being convolutionally re-encoded. This results in a symbol stream that can be compared on a symbol-by-symbol basis against the incoming

depunctured channel stream. Any discrepancy between two respective symbols indicates a corrected error (or with a much smaller probability, an erroneous output bit produced by a failure of the Viterbi decoder to decode correctly). For code rates other than rate equal to 1/2, the decoder disregards input symbols marked as erasures when it detects the error events.

The decoder processes the bit error events further to produce a measure of the actual channel bit error rate. The register VMDC2 (Group 4, APR 5:7) specifies the number of channel bits (and therefore the time period), divided by four, over which the decoder counts the number of occurring channel bit errors. Refer to Group 4, APR 5:7 or page 3-31 for a description of VMDC2.

The channel data error counter accumulates the errors internally and updates the Viterbi Bit Error Rate Count (VBERC, Group 3, APR 4:5) once at the end of the period specified by VMDC2. You can read the value of the VBERC using the microcontroller interface. VBERC contains the number of errors divided by four. In addition, the L64704 sets the VBER flag in the System Status Register (Group 2). This flag indicates that the decoder has reached the period specified by VMDC2. The decoder asserts INT if the corresponding interrupt enable bit, VBER\_IE, is set in the System Mode Register (Group 2). Refer to Section 3.4, "Group 2 Registers" on page 3-11 for details.

Typical threshold values for each puncturing rate in the case of a standard DVB application are shown in Table 7.2:

#### Table 7.2 Viterbi Threshold Values

| Puncturing<br>Rate | g<br>1/2 | 2/3   | 3/4  | 5/6  | 7/8  |
|--------------------|----------|-------|------|------|------|
| VMDC1              | 0x40     | 0x40  | 0x40 | 0x40 | 0x40 |
| VMBEC              | 0x1E     | 0x0E  | 0x0A | 0x07 | 0x05 |
| Ratio              | 23.6%    | 11.1% | 8.0% | 5.6% | 4.1% |

Figure 7.5 Block Diagram of Viterbi Bit Error Detection Circuit



To assist the proper selection of the ratio of the threshold values VMDC1 and VBERC, Figure 7.6 through Figure 7.10 show the plots of the percentages of symbol errors vs. Eb/No for all the code rates that the L64704 supports. The upper curve in each graph represents the out-ofsynchronization condition, and the lower curve represents the insynchronization condition.





0.0 ∟ 2

2.5

3

3.5

4

Eb/No (dB)

4.5

5

5.5

6



You must select a value for the ratio VMBEC/VMDC1 that is in between the in-synchronization and the out-of-synchronization curves. For example, for a rate equal to 1/2 code, a value of 0.24, or 24%, for VMBEC/VMDC1 establishes a valid decision threshold over the entire Eb/No range shown. Equation 7.1 shows the computation of Channel Symbol Error Percentages.

Equation 7.1 Channel Symbol Error Rate = 
$$\frac{128 VMBEC + 32}{256 VMDC1}$$

7.2

Module

Deinterleaver

Figure 7.11 outlines the interleaving/deinterleaving operation. The Interleaver is a device that rearranges the ordering of a sequence of symbols in a deterministic manner. A (B, N) Periodic Interleaver has the following characteristics:

- The minimum separation at the Interleaver output is B symbols for any two symbols that are separated by less than N symbols at the Interleaver input.
- If the channel inserts any burst of less than B errors, single errors occur at the Deinterleaver output.

This scheme is also called a convolutional Interleaver/Deinterleaver.





The L64704 Deinterleaver module performs periodic deinterleaving. The user must specify two parameters: B, the desired interleaving depth, and M, defined as:

$$M = \left\lceil \frac{N}{B} \right\rceil.$$

The L64704 Deinterleaver features:

- Convolutional deinterleaving
- Maximum block length of 204 bytes
- Deinterleaving depth of 12
- System clock rate up to 62.5 MHz

The Deinterleaver is comprised of two main modules:

7.2.1 Deinterleaver Block Diagram

- A set of configurable RAM-based delay lines that implement the proper delay for individual data bytes
- A controller that handles and generates the strobes needed by the following elements in the data path.

The modules are shown in the block diagram in Figure 7.12.



7.2.2 The Deinterleaver receives the rearranged byte stream and inverts the interleaver
 Deinterleaver
 Output
 The Deinterleaver receives the rearranged byte stream. The internal strobes indicate the block boundaries that the Deinterleaver must recover.

The Deinterleaver outputs the original byte stream after a delay given by:

Equation 7.2  $Delay = \{(B-1) \times B \times \lceil N/B \rceil + 1\} \times 8 + 1$ 

Figure 7.13 shows an example in which the total delay is  $\{2 \times 3 \times 2 + 1\} \times 8 + 1 = 105$  clock cycles. Notice that the delay from the first input byte to the first valid output byte is indeed 105 clock cycles.





| 7.3<br>Reed-Solomon<br>Decoder | The Reed Solomon Decoder is a Forward Error Correction unit that looks<br>at the check bytes that are appended to the data stream and either cor-<br>rects any errors that it finds in the data stream or asserts the<br>ERROROUT pin when it cannot correct the data. |                                                                                                                                                                                                                                                                                                                               |  |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7.3.1<br>Terms and<br>Concepts | with their ability                                                                                                                                                                                                                                                     | n Code (ECC) devices have a specific lexicon associated<br>y to correct transmission messages. This section defines<br>I for variables in the Reed-Solomon Core. The terms are<br>ut this document.                                                                                                                           |  |
|                                | R                                                                                                                                                                                                                                                                      | <b>Check Bytes</b><br>The encoder generates and appends check bytes to the incoming message according to the Reed-Solomon error correction encoding. The decoder uses check bytes to locate and correct errors caused by transmission. The system designer specifies the size of the check byte field within the limitations. |  |
|                                | d                                                                                                                                                                                                                                                                      | <b>Detection power</b><br>Detection power specifies the maximum number of detectable errors. Detection power has a minimum value of:<br>$\left\lfloor \frac{R}{2} \right\rfloor$ and a maximum value of R.                                                                                                                    |  |
|                                | к                                                                                                                                                                                                                                                                      | <b>Message Length</b><br>The message is comprised of multiple bytes. The size of<br>the message varies, depending on the code word length<br>and the check bytes used, where $K = N - R$ .                                                                                                                                    |  |
|                                | m                                                                                                                                                                                                                                                                      | <b>Symbol Size</b><br>A data transfer is comprised of multiple symbols and the<br>symbol size, m, is eight bits.                                                                                                                                                                                                              |  |
|                                | Ν                                                                                                                                                                                                                                                                      | <b>Codeword Length</b><br>This variable is the sum of the number of message bytes<br>and the number of check bytes $(K + R)$ . The value of N<br>is 204.                                                                                                                                                                      |  |
|                                | т                                                                                                                                                                                                                                                                      | Number of Error Corrections<br>This variable is the maximum number of error corrections<br>performed by the decoder. The value of T is 8.                                                                                                                                                                                     |  |

## 7.3.1.1 Forward Error Correction

Forward error correction requires an encoder that appends redundant check bytes to a message before transmission. The check bytes, with an indeterminate number of bits, are referred to as symbols. The message symbols followed by redundant check symbols are called code words. The check symbols are redundant in the sense that they are derived from the message and are appended to the message. Check symbols are also referred to as "redundant check bytes," and sometimes as "correction bytes."

Figure 7.14 illustrates a code word. Explanatory text follows the figure.

Figure 7.14 Code Word Structure

N Code Word Bytes

| K Message Bytes | R Redundant Check Bytes |
|-----------------|-------------------------|
|-----------------|-------------------------|

A code word is a block of N bytes that includes K message symbols and N - K check bytes (R). The check bytes or symbols are some fraction of the message symbols. A large number of check symbols allows the decoder to correct a large number of transmission errors.

The redundant check symbols in a message allow a decoder at the receiving end of a transmission line to detect transmission errors and reconstruct the original message content. Figure 7.15 shows a block diagram of the basic encoder and decoder functions in a transmission system.



After generating a code word, the encoder transmits it through a low cost channel to a decoder. The decoder compares the bit stream in the message data to the encoding in the check bytes to detect transmission

errors. The original message can be precisely reconstructed from the check symbols, as long as the number of errors in the code word is less than or equal to R/2.

## 7.3.1.2 Reed-Solomon Correction Codes

Reed-Solomon (RS) error correction codes are systematic and operate on bytes rather than single-bit data streams. They are especially good in burst error applications. The importance of RS codes is illustrated by their adoption as international and domestic standards in various areas of applications. The codes are expressed by convention as two numbers, the first indicating the total codeword length (N), and the second indicating the number of message bytes (K). The difference between these two numbers (N – K) is the number of check bytes. A (255, 233) RS code, for instance, with eight-bit bytes, was adopted as part of the standard for space missions by both the European Space Agency and NASA. The compact disc digital-audio system uses a combination of a (32, 28) RS code and a (28, 24) RS code. The MIL-STD-2179/ANSI X3B.6 media exchange standard uses a (161, 153) RS code and a (128, 118) RS code for high-density magnetic recording.

The L64704 uses the following generator polynomial for RS codes:

$$\prod_{i=0}^{\mathsf{R}-1}(x+\alpha^i)$$

where a is a root of the binary primitive polynomial:

 $x^8 + x^4 + x^3 + x^2 + 1$ 

A data byte  $(d_7, d_6, \dots, d_1, d_0)$  is identified with the element  $d_7a^7 + d_6a^6 + \dots + d_1a + d_0$  in GF(256), the finite field with 256 elements.

The error correcting power of an RS code is related to the number of redundant check symbols in its code words. In general, an RS code with 2T check symbols per code word can correct up to T byte errors per code word. Higher redundancy allows more errors to be corrected

The remainder of this section describes the process of correcting transmission errors with Reed-Solomon codes.

## 7.3.1.3 Error Handling and Correction

A bit error occurs when a transmitted zero is received as a one or vice versa. A byte error occurs when one or more bits in the byte have errors. For example, a byte with only one bit error is counted as one byte error, and a byte with m bit errors (all bits are inverted) is also counted as one byte error. As long as a code word has no more than  $T = \lfloor (R)/2 \rfloor$  byte errors, the RS Decoder corrects all errors. When a code word has more than  $T = \lfloor (R)/2 \rfloor$  byte errors, the RS decoder detects the presence of excessive errors and asserts the ERROROUT signal to notify the user.

Assume that the byte size is 8, the redundant check parameter is 32, and a 122-bit burst error is input to the RS decoder. The RS decoder can correct up to T = 16 byte errors. A 122-bit burst can be divided into 17 bytes as shown in Figure 7.16, where each *e* represents a one bit error. Because the redundancy is 32, the decoder corrects up to 16 byte errors. Because the 122-bit burst corrupts 17 consecutive bytes, the maximum guaranteed correctable burst length in this example is 121 bits.



### 7.3.2 Features

The Reed-Solomon Decoder features:

- ♦ 62.5 Mbits/s throughput
- Flag for corrected errors
- Complies with CCITT recommended CCIR723 standard for digital TV transmission
- DVB compliant
- Decoder channel output counts for uncorrected data and error vector data
- ERROROUT signal flags uncorrectable errors
- (204, 188) Reed-Solomon Code Format

## 7.3.3 Performance Analysis

The performance of the code against independent random byte errors can be computed by the equation:

Equation 7.3

$$= \sum_{i=T+1}^{N} \frac{i}{N} {N \choose i} p^{i} (1-p)^{N-i}$$

where:

q

- N Code word length in bytes
- p Input byte error rate

T Number of errors to correct

q Output byte error rate

 $\binom{N}{i}$ 

Binomial coefficient that represents the number of ways of choosing i items from a collection of N distinct items

When more than T byte errors occur in a code word, the RS Decoders usually detect the presence of excessive errors and raise the uncorrectable error flag to notify the user. However, there is a small probability that the erroneous decoded code word remains undetected. The undetected erroneous code word rate is:

$$\frac{1}{T!}\left(\frac{N}{2^m-1}\right)^T\sum_{i=T+1}^N\binom{N}{i}p^i(1-p)^{N-i}$$

For the code format (255, 223), the percentage redundancy of the RS code is 32/255 = 12.5%. With this modest amount of overhead, the coding system corrects error bursts of 16 bytes for T = 16. Figure 7.17 illustrates the random error correction capability with a codeword length of 255 when various correction values expressed as T are programmed into the device.



7.4 Descrambler Module Architecture and Operation Figure 7.18 shows a block diagram of the Descrambler. The Descrambler is composed of two modules:

- A module that generates a pseudorandom binary sequence (PRBS) that modifies the incoming data stream
- A control module that properly aligns data with the PRBS



The following generator polynomial produces the pseudorandom bit sequence in the Descrambler:

 $1 + x^{14} + x^{15}$ 

For initialization. a specific value is chosen for the 15-tap shift register shown in Figure 7.19.

Figure 7.19 15-bit Shift Register

Shift Register Initialization Sequence

|   | - | - | - | - | - | - |   | - | 0  | -  | -  | -  | -  | -  |
|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|
| 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |

The encoder inverts every eighth MPEG transport sync word (0x47) to generate a sync word (0xB8) that the decoder then uses to align the Descrambler with the incoming data stream. The first bit of the PRBS is applied to the first data bit following the inverting MPEG sync byte.

During the following seven noninverting MPEG sync words, the L64704 operates the Descrambler sequence generator, but does not modify the data stream. The L64704 resets the Descrambler after every inverting MPEG sync word.



# 7.5 FEC Module Software Reset

The L64704 resets the internal datapath and control modules for the FEC portion of the device when you set the FEC\_Reset bit (Group 4, APR 36) to 1. The demodulator module is not affected. You do not need to set the bit back to 0 to complete the reset. The L64704 issues a single reset pulse each time the microcontroller writes a one to this bit. When the FEC\_Reset bit is set, the L64704 resets the FEC processing unit and state machines to their initial states. The following operations occur when FEC\_Reset is asserted:

- Internal datapath and control modules reset
- Group 4 registers unaffected by RESET
- Group 3 UEC and CEC counters reset
- DVALIDOUT pin set LOW
- FSTARTOUT pin set LOW
- ♦ ERROROUT pin set HIGH

# Chapter 8 L64704 Specifications

|                   | This chapter provides the specifications for the L64704 Satellite Decoder from LSI Logic. The L64704 is implemented in LSI Logic's 0.5-micron, 3.3-volt LCB500K process. |  |  |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                   | This chapter contains the following sections:                                                                                                                            |  |  |  |  |
|                   | <ul> <li>Section 8.1, "Electrical Requirements," provides tables that describe<br/>the electrical characteristics of the L64704.</li> </ul>                              |  |  |  |  |
|                   | <ul> <li>Section 8.2, "AC Timing," includes timing diagrams and tables that<br/>list the various AC timing parameters.</li> </ul>                                        |  |  |  |  |
|                   | <ul> <li>Section 8.3, "L64704 Packaging," shows the pinouts of the device,<br/>and provides the mechanical specifications for the package.</li> </ul>                    |  |  |  |  |
| 8.1<br>Electrical | This section specifies the electrical requirements for the L64704 device.<br>Four tables list electrical data in the following categories:                               |  |  |  |  |
| Requirements      | <ul> <li>Absolute Maximum Ratings (Table 8.1)</li> </ul>                                                                                                                 |  |  |  |  |
|                   | <ul> <li>Recommended Operating Conditions (Table 8.2)</li> </ul>                                                                                                         |  |  |  |  |
|                   | Capacitance (Table 8.3)                                                                                                                                                  |  |  |  |  |
|                   | DC Characteristics (Table 8.4)                                                                                                                                           |  |  |  |  |
|                   | <ul> <li>Pin Description Summary (Table 8.5)</li> </ul>                                                                                                                  |  |  |  |  |

Table 8.1 L64704 Absolute Maximum Rating (Referenced to V<sub>SS</sub>)

| Symbol           | Parameter                           | Limits <sup>1</sup>           | Unit |
|------------------|-------------------------------------|-------------------------------|------|
| V <sub>DD</sub>  | DC Supply Voltage                   | -0.3 to +3.9                  | V    |
| V <sub>IN</sub>  | LVTTL Input Voltage                 | -1.0 to V <sub>DD</sub> + 0.3 | V    |
| VIN              | 5 V Compatible Input Voltage        | -1.0 to 6.5                   | V    |
| IIN              | DC Input Current                    | ±10                           | mA   |
| T <sub>STG</sub> | Storage Temperature Range (Plastic) | -40 to +125                   | °C   |

1. Note that the ratings in this table are those beyond which permanent device damage is likely to occur. These values should not be used as the limits for normal device operation.

Table 8.2 L64704 Recommended Operating Conditions

| Symbol          | Parameter                                        | Limits <sup>1</sup> | Unit |
|-----------------|--------------------------------------------------|---------------------|------|
| V <sub>DD</sub> | DC Supply Voltage                                | +3.14 to 3.47       | V    |
| T <sub>A</sub>  | Operating Ambient Temperature Range (Commercial) | 0 to +70            | °C   |
| Т <sub>С</sub>  | Case Temperature                                 | 0 to +85            | °C   |

 For normal device operation, adhere to the limits in this table. Sustained operation of a device at conditions exceeding these values, even if they are within the absolute maximum rating limits, may result in permanent device damage or impaired device reliability. Device functionality to stated DC and AC limits is not guaranteed if conditions exceed recommended operating conditions.

#### Table 8.3 L64704 Capacitance

| Symbol           | Parameter <sup>1</sup> | Max | Units |
|------------------|------------------------|-----|-------|
| C <sub>IN</sub>  | Input Capacitance      | 5   | pF    |
| C <sub>OUT</sub> | Output Capacitance     | 5   | pF    |

1. Measurement conditions are V\_{IN} = 3.3 V, T\_A = 25  $^\circ\text{C},$  and clock frequency = 1 MHz.

Table 8.4 L64704 DC Characteristics

| Symbol            | Parameter <sup>1</sup>                                                       | Condition <sup>2</sup>                                                         | Min                   | Тур        | Max                   | Unit |
|-------------------|------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-----------------------|------------|-----------------------|------|
| V <sub>DD</sub>   | Supply Voltage                                                               |                                                                                | 3.14                  | 3.3        | 3.47                  | V    |
| V <sub>IL</sub>   | Input Voltage LOW                                                            |                                                                                | V <sub>SS</sub> - 0.5 |            | 0.2 V <sub>DD</sub>   | V    |
| V <sub>IH</sub>   | Input Voltage HIGH                                                           | LVTTL Com/Ind/Mil<br>Temp Range                                                | 0.7 V <sub>DD</sub>   |            | V <sub>DD</sub> + 0.3 | V    |
|                   |                                                                              | 5-volt Compatible                                                              | 0.7 V <sub>DD</sub>   |            | 5.5                   | V    |
| V <sub>T</sub>    | Switching Threshold                                                          |                                                                                |                       | 1.4        | 2.0                   | V    |
| IIL               | Input Current Leakage                                                        | V <sub>DD</sub> = Max,<br>V <sub>IN</sub> = V <sub>DD</sub> or V <sub>SS</sub> | -10                   | <u>+</u> 1 | 10                    | mA   |
| I <sub>IPU</sub>  | Input Current Leakage with Pull-up                                           | $V_{IN} = V_{SS}$                                                              | -62                   | -215       | -384                  | mΑ   |
| I <sub>IPD</sub>  | Input Current Leakage with<br>Pull-down                                      | $V_{IN} = V_{DD}$                                                              | 62                    | 215        | 384                   | mA   |
| V <sub>OH</sub>   | Output Voltage HIGH                                                          | I <sub>OH</sub> = -1.0, -2.0, -4.0,<br>-6.0, -8.0, -12.0 mA                    | 2.4                   |            | V <sub>DD</sub>       | V    |
| V <sub>OL</sub>   | Output Voltage LOW                                                           | I <sub>OH</sub> = 1.0, 2.0, 4.0, 6.0,<br>8.0, 12.0 mA                          |                       | 0.2        | 0.4                   | V    |
| I <sub>OZ</sub>   | 3-state Output Leakage Current                                               | V <sub>DD</sub> = Max,<br>V <sub>OUT</sub> = V <sub>SS</sub> or 3.5 V          | -10                   | <u>+</u> 1 | 10                    | μA   |
| I <sub>OSP4</sub> | Current P-Channel Output Short<br>Circuit (4-mA Output Buffers) <sup>3</sup> | V <sub>OUT</sub> = V <sub>SS</sub>                                             | 24                    |            | 114                   | mA   |
| I <sub>OSN4</sub> | Current N-Channel Output Short<br>Circuit (4-mA Output Buffers) <sup>3</sup> | V <sub>OUT</sub> = V <sub>DD</sub>                                             | -31                   | -60        | -93                   | mA   |
| I <sub>DD</sub>   | Quiescent Supply Current                                                     | $V_{IN} = V_{DD} \text{ or } V_{SS}$                                           |                       |            | 2                     | mA   |
| I <sub>CC</sub>   | Dynamic Supply Current                                                       | f = 62.5 MHz,<br>V <sub>DD</sub> = Max                                         |                       | 200        |                       | mA   |

1. To identify an input with an internal pull-up or pull-down resistor or an output's drive strength, see Table 8.5, L64704 Pin Description Summary.

2. Specified at  $V_{DD}$  = 3.3 V ± 5% at ambient temperature over the specified range. 3. Not more than one output may be shorted at a time for a maximum duration of one second. The values specified are for the 4-mA output buffers. The values for other output buffers scale accordingly.

#### Table 8.5 L64704 Pin Description Summary

| Mnemonic     | Description                 | Туре                        | Drive (mA) | Active |
|--------------|-----------------------------|-----------------------------|------------|--------|
| A[2:0]       | Address                     | TTL Input with Pull-down    | _          | _      |
| ĀS           | Address strobe              | TTL Input with Pull-up      | -          | LOW    |
| BCLKOUT      | Byte Clock Out              | Output                      | 4          | _      |
| CAR_DCLKP    | Pre-scaled Carrier VCO      | PECL/CMOS/TTL Input         | -          | DIFF   |
| CAR_DCLKN    | Pre-scaled Carrier VCO      | PECL/CMOS/TTL Input         | -          | DIFF   |
| CAR_PED[1:0] | Phase Error Detector to DAC | Output                      | 4          | _      |
| CAR_VCO1P    | Carrier Loop Control        | Differential 3-state Output | 4          | _      |
| CAR_VCO1N    | Carrier Loop Control        | Differential 3-state Output | 4          | _      |
| CAR_VCO2P    | Carrier Loop Control        | Differential 3-state Output | 4          | _      |
| CAR_VCO2N    | Carrier Loop Control        | Differential 3-state Output | 4          | _      |
| CLK          | RI/Q Samples Clock          | TTL Input                   | -          | _      |
| CLK_VCOP     | Clock Loop Control          | Differential 3-state Output | 4          | _      |
| CLK_VCON     | Clock Loop Control          | Differential 3-state Output | 4          | _      |
| CO[7:0]      | Channel Output              | 3-State Output              | 4          | _      |
| COE          | Channel Output Enable       | TTL Input with Pull-up      | -          | LOW    |
| CS           | Chip Select                 | TTL Input with Pull-up      | -          | LOW    |
| D[7:1]       | Data                        | Bidirectional TTL           | 4          | _      |
| D[0]         | Data                        | Bidirectional TTL           | 4          | _      |
| DTACK        | Data Acknowledge            | 3-State Output              | 4          | LOW    |
| DVALIDOUT    | Data Valid Output           | Output                      | 4          | HIGH   |
| ERROROUT     | Uncorrected Error Flag      | 3-State Output              | 4          | LOW    |
| FSTARTOUT    | Framestart Output           | Output                      | 4          | HIGH   |
| HOST_MODE    | Interface Selector          | Input                       | -          | HIGH   |
| IDDTN        | Test Pin                    | Input                       | -          | HIGH   |
| INT          | Interrupt                   | 3-State Output              | 4          | LOW    |
| LP2          | PLL Loop Filter             | Input                       | -          | _      |
| OCLK         | FEC Clock                   | Input                       | -          | _      |
| PCLK         | PLL Output Clock            | Output                      | 4          | _      |
| PLLVDD       | PLL V <sub>DD</sub>         | Input                       | -          | _      |
| PLLVSS       | PLL Vss                     | Input                       | -          | _      |
| PLLAGND      | PLL Analog Ground           | Input                       | -          | _      |

(Sheet 1 of 2)

Table 8.5 (Cont.) L64704 Pin Description Summary

| Mnemonic      | Description                 | Туре                   | Drive (mA) | Active |
|---------------|-----------------------------|------------------------|------------|--------|
| PWRP          | Power Loop Control          | 3-State Output         | 6          | HIGH   |
| READ          | Read Write                  | TTL Input with Pull-up | _          | HIGH   |
| RESET         | Chip Reset                  | TTL Input              | _          | HIGH   |
| RI[5:0]       | Received I Samples          | TTL Inputs             | _          | _      |
| RQ[5:0]       | Received Q Samples          | TTL Inputs             | _          | _      |
| SDATA         | Serial Interface Data       | Bidirect               | 4          | _      |
| SYNC/SCLK     | Sync Status Flag            | Output                 | 4          | _      |
| XCTR_OUT[3:0] | External Controls           | CMOS Outputs           | 4          | _      |
| XCTR_IN       | External Controls           | CMOS Input             | _          | _      |
| XOIN          | Input from External Crystal | CMOS Input             | -          | _      |
| XOOUT         | Output to External Crystal  | CMOS Output            | 40         | _      |

(Sheet 2 of 2)

## 8.2 AC Timing

This section presents AC timing information for the L64704. During AC testing, HIGH inputs are driven to 3.0 V and LOW inputs are driven at 0 V. For transitions between HIGH, LOW, and invalid states, timing measurements are made at 1.5 V, as shown in Figure 8.1.

Figure 8.1 AC Test Load and Waveform for Standard Outputs



MD94.361

For 3-state outputs, timing measurements are made from the point at which the output turns ON or OFF. An output is ON when its voltage is greater than 2.5 V or less than 0.5 V. An output is OFF when its voltage is less than  $V_{DD} - 0.5$  V or greater than 0.5 V, as shown in Figure 8.2.

Figures 8.3 through 8.7 show the various timing diagrams for the L64704. The numbers shown in the diagrams refer to parameters shown in Table 8.6.







Figure 8.7 L64704 Decoder Write Cycle



The numbers in column 1 of Table 8.6 refer to the timing parameters shown in the preceding figures. All parameters in the timing tables apply for  $T_A = 0$  °C to 70 °C and a capacitive load of 15 pF.

#### Table 8.6 L64704 AC Timing Parameters

|                |                    |                         |                     | 62.5 MHz |      |             |
|----------------|--------------------|-------------------------|---------------------|----------|------|-------------|
| Parameter      |                    | Description             | Groups <sup>1</sup> | Min      | Max  | Unit        |
| 1              | t <sub>CYCLE</sub> | Clock Cycle OCLK, CLK   |                     | 16.0     | Ι    | ns          |
| 2              | t <sub>PWH</sub>   | Clock Pulse Width High  |                     | 7.0      | -    | ns          |
| 3              | t <sub>PWL</sub>   | Clock Pulse Width Low   |                     | 7.0      | -    | ns          |
| 4              | t <sub>S</sub>     | Input Setup Time to CLK |                     | 3.0      | _    | ns          |
| 5              | t <sub>H</sub>     | Input Hold to CLK       |                     | 1.0      | -    | ns          |
| 6              | t <sub>OD</sub>    | Output Delay from OCLK  |                     | 3.0      | 12.0 | ns          |
| 7              | t <sub>RWH</sub>   | Reset Pulse Width High  |                     | 3        | _    | OCLK Cycles |
| 8              | t <sub>WK</sub>    | Wake-up Time            |                     | 280      | -    | OCLK Cycles |
| 9              | T <sub>DLY</sub>   | Delay from COE          |                     | _        | 15.0 | ns          |
| (Sheet 1 of 2) |                    |                         |                     |          |      |             |

#### Table 8.6 (Cont.) L64704 AC Timing Parameters

|           |                       |                                                               |                            | 62.5 MHz    |             |                   |
|-----------|-----------------------|---------------------------------------------------------------|----------------------------|-------------|-------------|-------------------|
| Parameter |                       | Description                                                   | Groups <sup>1</sup>        | Min         | Max         | Unit              |
| 10        | t <sub>SURCS</sub>    | READ Setup Before CS Low                                      |                            | 0.0         | -           | ns                |
| 11        | t <sub>SUA</sub>      | A[2:0] Setup Before AS Low                                    |                            | 15.0        | -           | ns                |
| 12        | t <sub>HLDA</sub>     | A[2:0] Hold After AS Low                                      | Groups 0,1,4<br>Groups 2,3 | 0.0<br>3.0  | Ι           | ns<br>OCLK Cycles |
| 13        | t <sub>DCSDTL</sub>   | Data Valid to DTACK Low                                       | Groups 0,1,4<br>Groups 2,3 | -           | 25.0<br>3.0 | ns<br>OCLK Cycles |
| 14        | t <sub>HLDD</sub>     | Write Data Hold After $\overline{CS}$ High                    |                            | 0.0         | 1           | ns                |
| 15        | t <sub>CYCLE_CS</sub> | Minimum CS Width                                              | Groups 0,1,4<br>Groups 2,3 | 30.0<br>4.0 | Ι           | ns<br>OCLK Cycles |
| 16        | t <sub>HLDRCS</sub>   | READ Hold After CS High                                       |                            | 0.0         | -           | ns                |
| 17        | t <sub>WRREC</sub>    | Write Recovery Time                                           | Groups 0,1,4<br>Groups 2,3 | 30.0<br>3.0 | Ι           | ns<br>OCLK Cycles |
| 18        | t <sub>DCSDTH</sub>   | $\overline{\text{CS}}$ High to $\overline{\text{DTACK}}$ High | Groups 0,1,4<br>Groups 2,3 | -           | 40.0<br>5.0 | ns<br>OCLK Cycles |
| 19        | t <sub>DELZL</sub>    | $\overline{\text{CS}}$ Low to Data Driven                     | Groups 0,1,4               | 9.0         | -           | ns                |
| 20        | t <sub>DELD</sub>     | $\overline{\text{CS}}$ Low to Data Valid                      | Groups 0,1,4<br>Groups 2,3 | -           | 45.0<br>4.0 | ns<br>OCLK Cycles |
| 21        | t <sub>DELLZ</sub>    | CS High to Data 3-State                                       | Groups 0,1,4<br>Groups 2,3 | 5.0<br>0.5  | 12.0<br>2.0 | ns<br>OCLK Cycles |
| 22        | t <sub>SUD</sub>      | Data Setup Before CS<br>Change                                |                            | 15.0        | -           | ns                |
| 23        | t <sub>HLDW</sub>     | AS Hold After CS Low                                          | Groups 0,1,4<br>Groups 2,3 | 10.0<br>2.0 | Ι           | ns<br>OCLK Cycles |
| 24        | t <sub>DELDTL</sub>   | CS Low to DTACK Low                                           | Groups 0,1,4<br>Groups 2,3 | _           | 45.0<br>5.0 | ns<br>OCLK Cycles |
| 25        | t <sub>RDREC</sub>    | Read Recovery Time                                            | Groups 0,1,4<br>Groups 2,3 | 30.0<br>3.0 | _           | ns<br>OCLK Cycles |
| (She      | et 2 of 2)            |                                                               |                            |             |             |                   |

1. The groups referred to are the register groups shown in Table 3.1 on page 3-2.

8.3 This section specifies the type of package in which the L64704 is available. Table 8.7 lists ordering information for the L64704. The table and figures that follow provide three types of package information: an alphabetical pin list, a pinout, and a mechanical drawing.

| Table 8.7<br>L64704 Ordering Info | ormation<br>Order Number | Clock<br>Frequency<br>(MHz) | Package Type | Operating<br>Range |
|-----------------------------------|--------------------------|-----------------------------|--------------|--------------------|
|                                   | L64704B                  | 62.5                        | 100-pin PQFP | Commercial         |

Table 8.8 Alphabetical Pin List for the 100-pin PQFP

| Signal    | Pin | Signal    | Pin | Signal    | Pin    | Signal    | Pin |
|-----------|-----|-----------|-----|-----------|--------|-----------|-----|
| A0        | 27  | CS        | 24  | RI0       | 11     | VDD       | 78  |
| A1        | 26  | D0        | 43  | RI1       | 10     | VDD       | 86  |
| A2        | 25  | D1        | 42  | RI2       | 9      | VDD       | 93  |
| AS        | 23  | D2        | 39  | RI3       | 8<br>7 | VDD       | 98  |
| BCLKOUT   | 51  | D3        | 38  | RI4       |        | VSS       | 3   |
| CAR_DCLKN | 4   | D4        | 37  | RI5       | 6      | VSS       | 13  |
| CAR_DCLKP | 5   | D5        | 36  | RQ0       | 19     | VSS       | 21  |
| CAR_PED0  | 95  | D6        | 35  | RQ1       | 18     | VSS       | 29  |
| CAR_PED1  | 94  | D7        | 33  | RQ2       | 17     | VSS       | 40  |
| CAR_VCO1N | 89  | DTACK     | 30  | RQ3       | 16     | VSS       | 46  |
| CAR_VCO1P | 91  | DVALIDOUT | 67  | RQ4       | 15     | VSS       | 52  |
| CAR_VCO2N | 88  | ERROROUT  | 68  | RQ5       | 14     | VSS       | 58  |
| CAR_VCO2P | 90  | FSTARTOUT | 69  | SDATA     | 44     | VSS       | 66  |
| CLK       | 22  | HOST_MODE | 1   | SYNC/SCLK | 50     | VSS       | 72  |
| CLK_VCON  | 97  | IDDTN     | 100 | VDD       | 2      | VSS       | 79  |
| CLK_VCOP  | 96  | INT       | 32  | VDD       | 12     | VSS       | 85  |
| CO0       | 54  | LP2       | 76  | VDD       | 20     | VSS       | 92  |
| CO1       | 55  | OCLK      | 71  | VDD       | 28     | VSS       | 99  |
| CO2       | 56  | PCLK      | 73  | VDD       | 34     | XCTR_IN   | 80  |
| CO3       | 57  | PLLAGND   | 75  | VDD       | 41     | XCTR_OUT0 | 81  |
| CO4       | 60  | PLLVDD    | 74  | VDD       | 47     | XCTR_OUT1 | 82  |
| CO5       | 61  | PLLVSS    | 77  | VDD       | 53     | XCTR_OUT2 | 83  |
| CO6       | 62  | PWRP      | 87  | VDD       | 59     | XCTR_OUT3 | 84  |
| CO7       | 63  | READ      | 31  | VDD       | 65     | XOIN      | 48  |
| COE       | 64  | RESET     | 45  | VDD       | 70     | XOOUT     | 49  |

Figure 8.8 L64704 100-Pin PQFP Pinout



#### Figure 8.9 100-Pin PQFP Mechanical Drawing (Sheet 1 of 2)



8-12

#### Figure 8.9 (Cont.) 100-Pin PQFP Mechanical Drawing (Sheet 2 of 2)



# Appendix A Programming the L64704 Using the Serial Bus Protocol

This appendix discusses how to program the L64704 internal registers and data tables in Serial Host Interface mode. This chapter is intended primarily for system programmers who are developing software drivers using the serial bus.

This chapter contains the following sections:

- Section A.1, "Serial Bus Protocol Overview," provides a high-level overview of the serial bus protocol.
- Section A.2, "Programming the Slave Address Using the Serial Bus Interface," shows how the slave address is formed and transmitted.
- Section A.3, "Write Cycle Using the Serial Bus Interface," shows an example of a serial bus write cycle.
- Section A.4, "Read Cycle Using the Serial Bus Interface," shows an example of a serial bus read cycle.

A.1The multi-master serial bus interface has two one-bit lines – SDATASerial Bus(Serial Data) and D[0] (Serial Clock) – that are connected to the bus as<br/>shown in Figure A.1. External pullup resistors are used to hold the bus<br/>at a logic "1" value when the bus is not in operation.

Figure A.1 Quick Overview of the Serial Bus



Serial Host Interface mode is selected by driving the HOST\_MODE input pin to LOW. In Serial Host Interface mode, data is transferred on the SDATA pin, synchronized to a serial clock that is input on the LSB of the Host Data Bus, D0. The serial data clock can have a maximum frequency of 400 kHz. The remaining Host Data Bus pins, D[7:1], are used to input the slave address that is required by the serial bus protocol.

The bus master always generates the clock and cycle start and stop conditions. Figure A.2 gives an overview of the Read and the Write cycles using the Serial Bus Protocol.

Figure A.2 Quick Overview of Serial Bus Write/Read Cycles



indicate cvcle Start/Stop.

Acknowledge: The receiver always generates the acknowledge. In the case of a single read, the master-receiver does not generate an ACK so that it can generate the Stop condition (as indicated above).

# A.2 Programming the Slave Address Using the Serial Bus Interface

A general call (Master does a start condition followed by eight 0's as shown in Figure A.3) address is used to address every device on the serial bus. Any device that requires information to be supplied through this general call structure should acknowledge the cycle. The second byte has the following meaning when its LSB is "0":

**00000110 (0x6)** Reset and write the programmable part of the slave address by hardware. For the L64704, this means reading the D[7:1] pins. (These pins are unused when the serial interface is in use, and can be hardwired to any legal 7-bit address value).

Figure A.3 General Call Structure

| A.3<br>al Call | s                    | 0 | 0   | 0   | 0    | 0     | 0   | 0   | 0 | А | х | х | х | х | х | х | х | 0 | А |
|----------------|----------------------|---|-----|-----|------|-------|-----|-----|---|---|---|---|---|---|---|---|---|---|---|
| re             | General Call Address |   |     |     |      |       |     |     |   |   |   |   |   |   |   |   |   |   |   |
|                |                      | ( | Jen | era | I Ca | all A | ۱dd | res | s |   |   |   |   |   |   |   |   |   |   |

1. S = Start Condition.

2. A = Acknowledge Cycle.

| A.3<br>Write Cycle                | Refer to the following figure for a burst, or a single write cycle. The fol-<br>lowing cycles must take place for a write cycle: |                                                                                                                                          |  |  |  |  |  |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Using the Serial<br>Bus Interface | 1.                                                                                                                               | The master starts the cycle with the start condition.                                                                                    |  |  |  |  |  |
|                                   | 2.                                                                                                                               | The master transmits the 7-bit slave address.                                                                                            |  |  |  |  |  |
|                                   | 3.                                                                                                                               | The master transmits an eighth bit (the R/W bit) = 0 to indicate a write cycle.                                                          |  |  |  |  |  |
|                                   | 4.                                                                                                                               | The addressed slave acknowledges the reception of the slave address by driving SDATA low in the ACK cycle.                               |  |  |  |  |  |
|                                   | 5.                                                                                                                               | The master sends the 8-bit Group 0 address $(0x0)$ to indicate that the APR is to be loaded. (Group 0 is accessed only to load the APR). |  |  |  |  |  |
|                                   | 6.                                                                                                                               | The master then sends the 8-bit data. This data is used to initialize the Address Pointer register (APR0/1).                             |  |  |  |  |  |
|                                   | 7.                                                                                                                               | The master generates another start condition.                                                                                            |  |  |  |  |  |
|                                   | 8.                                                                                                                               | The master repeats steps 2-7 to address the appropriate group and write one or more data bytes.                                          |  |  |  |  |  |
|                                   | 9.                                                                                                                               | The master terminates the cycle by issuing a stop condition.                                                                             |  |  |  |  |  |

Figure A.4 Burst Write to Slave (Master-Transmitter, Slave-Receiver)



| A.4<br>Read Cycle                 |     | ease refer to the following figure for a burst, or a single read cycle. The owing cycles must take place for a read cycle:                                                                                                                                                                                                                                                           |
|-----------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Using the Serial<br>Bus Interface | 1.  | The master starts the cycle by issuing a start condition.                                                                                                                                                                                                                                                                                                                            |
|                                   | 2.  | The master transmits the 7-bit slave address.                                                                                                                                                                                                                                                                                                                                        |
|                                   | 3.  | The master sets the R/W bit = 0 to indicate a write cycle.                                                                                                                                                                                                                                                                                                                           |
|                                   | 4.  | The addressed slave acknowledges the reception of the slave address by driving SDATA low in the ACK cycle.                                                                                                                                                                                                                                                                           |
|                                   | 5.  | The Master sends the 8-bit Group 0 address(0x0) to indicate that the APR is to be loaded. (Group 0 is accessed only to load the APR).                                                                                                                                                                                                                                                |
|                                   | 6.  | The master then sends the 8-bit data. This data is used to initialize the base pointer (APR0/1).                                                                                                                                                                                                                                                                                     |
|                                   | 7.  | The master does a repeat start condition.                                                                                                                                                                                                                                                                                                                                            |
|                                   | 8.  | The master transmits the 7-bit slave address.                                                                                                                                                                                                                                                                                                                                        |
|                                   | 9.  | The master sets the R/W bit = 0 to indicate a write cycle.                                                                                                                                                                                                                                                                                                                           |
|                                   | 10. | The addressed slave acknowledges the reception by driving SDATA low in the ACK cycle.                                                                                                                                                                                                                                                                                                |
|                                   | 11. | The master transmits the number of the group that it wishes to read (which is acknowledged by the slave).                                                                                                                                                                                                                                                                            |
|                                   | 12. | The master issues another start condition.                                                                                                                                                                                                                                                                                                                                           |
|                                   | 13. | The master transmits the 7-bit slave address.                                                                                                                                                                                                                                                                                                                                        |
|                                   | 14. | The master sets the R/W bit = 1 to indicate a read cycle.                                                                                                                                                                                                                                                                                                                            |
|                                   | 15. | The slave drives SDATA LOW to acknowledge.                                                                                                                                                                                                                                                                                                                                           |
|                                   | 16. | The slave starts transmitting the data, MSB first.                                                                                                                                                                                                                                                                                                                                   |
|                                   | 17. | The master has to provide the acknowledge by driving SDATA LOW during the ACK cycle.                                                                                                                                                                                                                                                                                                 |
|                                   | 18. | In the case of a single read, the master does not drive SDATA low<br>during the ACK cycle after reception of the first byte. The slave<br>responds to this by relinquishing control of the bus and waiting for<br>the master to issue a stop condition. For burst reads, the master<br>drives SDATA low for each byte it receives during the ACK cycle,<br>except for the last byte. |
|                                   | 19  | The master terminates the cycle by issuing a stop condition                                                                                                                                                                                                                                                                                                                          |

19. The master terminates the cycle by issuing a stop condition.

Figure A.5 Single Read From Slave



Programming the L64704 Using the Serial Bus Protocol

# Appendix B L64704 Application Notes

This appendix provides updated information on the use of LSI Logic's L64704 Satellite Decoder in a typical application. It is divided into these sections:

- Section B.1, "Controlling the L64704's BPSK/QPSK Demodulator Loops," describes how to program and monitor the L64704's AGC Clock Synchronization and Carrier Synchronization loops.
- Section B.2, "L64704 QPSK Demodulator Debugging Tips," provides information on how to debug problems in the L64704's demodulator.
- Section B.3, "QPSK Demodulator Configuration Example," shows an example of how the demodulator portion of the L64704 can be programmed.
- Section B.4, "Configuring the L64704 FEC Decoder to the DVB Specifications," shows an example of how the FEC Decoder can be programmed to adhere to the DVB specifications.

B.1 Controlling the L64704's BPSK/QPSK Demodulator Loops The QPSK Demodulator portion of the L64704 has three independent loops that a microcontroller must configure properly. The first loop to monitor is the AGC loop. After the microcontroller ensures the AGC loop is working, it can proceed to the Clock Synchronization and Carrier Synchronization loops. Figure B.1 is a flow diagram that explains the simple process that runs on the microcontroller. You should program the microcontroller to monitor the L64704's flags.

# Table B.1 shows the registers and flags that are referred to in Figure B.1.

## Table B.1 QPSK Demodulator Loop Registers

| Mnemonic    | Description                              | Group | APR | Bit(s) |
|-------------|------------------------------------------|-------|-----|--------|
| CLK_LCF     | Clock Frequency Lock Flag                | 3     | 9   | 3      |
| CAR_THSL    | Threshold for Carrier Lock Detector      | 4     | 27  | 7:0    |
| CAR_VCO1N/P | CAR_VCO1N/P Outputs Active<br>or 3-state | 4     | 33  | 4      |
| CAR_SWR     | Sweep Rate for Carrier Sweep             | 4     | 28  | 7:0    |
| CAR_CONFIG  | Carrier Loop Configuration Register      | 3     | 33  | 7:0    |
| CAR_LC      | Carrier Frequency Lock Flag              | 3     | 9   | 5      |
| S1          | Stage 1 (Viterbi) Synchronization Flag   | 3     | 9   | 0      |



| B.2            | This section presents a debugging procedure to follow in case the |
|----------------|-------------------------------------------------------------------|
| L64704 QPSK    | L64704's QPSK demodulator fails to lock.                          |
| Demodulator    |                                                                   |
| Debugging Tips |                                                                   |

# B.2.1The AGC loop must lock first. When the AGC loop is closed, the signalAGC Looplevel at the Analog to Digital Convertor's (ADC) input is 0.588 (1/1.7)times the ADC range, assuming the PWR\_REF register (Group 4, APR<br/>19) is set to 84.

A simple test that you can perform is to change the power of the transmitted signal and observe the I or Q channels with an oscilloscope just before the ADC's input. Make sure that the peak-to-peak signal range is about 1/1.7 of the peak-to-peak ADC range. Also check that the AGC can keep the signal level fixed even when the transmitted power is changed. Observe that the AGC voltage at the loop's output is changing with the changes in the transmitted power. You may need to switch the polarity of the PWRP output by toggling the PWRP bit (Group 4, APR 35).

The following parameters are related to the AGC loop:

**PWR\_REF[7:0]; Group 4, APR19** – This parameter controls the signal level at the input of the ADC. It should be set to 84.

**PWR\_LVL[7:0]; Group 3, APR 8** – This read-only register is proportional to the mean value of the sigma-delta output. If the AGC amplification range is 0 dB to -30 dB, Table B.2 shows corresponding PWR\_LVL settings and amplification levels.

| Table B.2<br>PWR_LVL Register<br>Setting | PWR_LVL<br>Setting | Amplification (dB) |
|------------------------------------------|--------------------|--------------------|
|                                          | 0                  | 0                  |
|                                          | 128                | -15                |
|                                          | 255                | -30                |

**SCALE[7:0]; Group 4, APR 21** – This parameter controls the internal signals DEMI and DEMQ (see Figure 1.1 on page 1-2). It does not affect the loop itself, but it is related to PWR\_REF by Equation B.1.

Equation B.1 SCALE  $\times \sqrt{2(PWR\_REF)} = 2047$ 

So if  $PWR\_REF = 84$ , then SCALE = 158.

**PWRP Pin** – Connect the L64704's PWRP output pin to 5 volts using a 470 ohm pull-up resistor. The PWRP pin is then connected to an RC loop filter with a time constant of ~ 60 microseconds. Figure B.2 shows how to connect the PWRP pin to the AGC circuit.





For more information on the AGC loop, see Section 5.7, "Automatic Gain Control (AGC)."

B.2.2The design of the board should keep the two  $\Sigma\Delta$  (Sigma Delta) linesClock LoopCLK\_VCON and CLK\_VCOP parallel and minimize the distance from the<br/>L64704 output to the op-amp's input.

The microcontroller software has limited control over the clock loop. Set the loop's bandwidth according to Table 5.2 on page 5-8. Table B.3 shows the registers that are used to control the clock loop and Section 5.5, "Channel Clock Recovery" explains their function.

Table B.3 QPSK Demodulator Loop Registers

| Mnemonic       | Description                          | Group | APR   | Bit(s) |
|----------------|--------------------------------------|-------|-------|--------|
| CLK_LCF        | Clock Frequency Lock Flag            | 3     | 9     | 3      |
|                | Clock Loop Control Register 1        |       | 14    | 7:0    |
|                | Clock Loop Control Register 2        |       | 15    | 7:0    |
| CLK_NF[15:0]   | Nominal Frequency of the Clock Input |       | 16:17 | 7:0    |
| CLK_RATIO[2:0] | Clock Ratio                          |       | 18    |        |

Check that the clock frequency is not stuck at the rail, and that the opamp's output voltage is not stuck at either 0 volts or the supply voltage. The CLK\_VCO\_SWAP bit (Group 4, APR 14, bit 2) controls the polarity of the CLK\_VCOP/N signals.

To verify that the clock loop functions, trigger the ADC clock against the BERT's clock. If the clock loop is functioning normally, then the two clocks are in phase.

The CLK\_LCF status bit (Group 3, APR 9, bit 3) indicates whether the clock loop is locked. The indication is for frequency lock and the flag should be ON as soon as you finish programming the configuration (Group 4) registers.

- B.2.3The layout of the board should keep the two pairs of  $\Sigma\Delta$  lines,Carrier LoopCAR\_VCOxN and CAR\_VCOxP, parallel and minimize the distance from<br/>the L64704 output to the op-amp's input. The following paragraphs out-<br/>line a simple test to verify that the carrier loop functions:
  - Set the CAR\_SW and CAR\_OPEN bits in the Carrier Loop Configuration register (Group 4, APR 33) to b11. This forces the sweep to begin and disables the AFC.
    - Change the upper and lower sweep limits registers (CAR\_USWL and CAR\_LSWL; Group 4, APR 29:32) and watch the prescaler with a spectrum analyzer to see how the programmed values control the sweep range.
    - Change the value in the Carrier Sweep Rate register (CAR\_SWR; Group 4, APR 28) to ensure that it is controlling the sweep rate.

- Set the CAR\_SW and CAR\_OPEN bits in the Carrier Loop Configuration register to b01 and see if the carrier locks. The microcontroller should monitor the content of the STATUS register (Group 3, APR 9). If the CAR\_LC and CAR\_LCF bits both = 1, then clear bits 0 and 1 of the CAR\_CONFIG register to stop the sweep. If the sweep rate is fast, you may not be able to turn the sweep off fast enough through manual intervention; the microcontroller will have to do this in real time.
- If the carrier always goes to the rail, then change the CAR\_SWP\_SWAP and CAR\_VCO\_SWAP bits in the Carrier Loop Configuration register. These bits control the sweep direction and the polarity of the CAR\_VCOxN/P outputs. If changing polarity does not help, disconnect the op-amp's output and drive the VCO with a power supply to see whether changing the voltage controls the frequency.
- If the prescaler output is at a proper frequency and the op-amp's output is not at the rail, look at the eye pattern to see where the data is being sampled. A good test is to trigger the ADC's I or Q inputs against the ADC's clock (see Figure 4.1 on page 4-2). The clock must sample the data at the maximum eye opening.

| B.2.4<br>QPSK            |         | he following steps summarize how to debug the QPSK Demodulator or a system that includes the L64704.                                                                                                                                |  |  |  |  |  |
|--------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Demodulator<br>Debugging | Step 1. | Ensure that the AGC loop functions properly.                                                                                                                                                                                        |  |  |  |  |  |
| Summary                  | Step 2. | Ensure that the clock loop is locked.                                                                                                                                                                                               |  |  |  |  |  |
|                          | Step 3. | Set the CAR_SW and CAR_OPEN bits in the Carrier Loop<br>Configuration register to b11. This setting forces sweep to<br>begin and disables the AFC.                                                                                  |  |  |  |  |  |
|                          |         | <ul> <li>Change the Carrier Upper and Lower Sweep Limits registers<br/>(Group 4, APR 29:32) and watch the carrier prescaler with a<br/>spectrum analyzer to see how the programmed values con-<br/>trol the sweep range.</li> </ul> |  |  |  |  |  |
|                          |         | <ul> <li>Change the value in the Carrier Sweep Rate register (Group 4, APR 28) to ensure that it is controlling the sweep rate.</li> </ul>                                                                                          |  |  |  |  |  |
|                          | Step 4. | If the carrier always goes to the rail, then change the CAR_SWP_SWAP and CAR_VCO_SWAP bits in the Carrier                                                                                                                           |  |  |  |  |  |
|                          |         |                                                                                                                                                                                                                                     |  |  |  |  |  |

Loop Configuration register. These bits control the sweep direction and the polarity of the CAR\_VCOxN/P outputs.

- Step 5. Set the CAR\_SW and CAR\_OPEN bits in the Carrier Loop Configuration register to b01. The loop should now lock or at least slow down near the center of the frequency range.
- Step 6. If the carrier still does not lock, check the following parameters:
  - ♦ CAR\_KP
  - ◊ CAR\_KD
  - ♦ CAR\_SWR
  - Recalculate RC values

Each one of these parameters affects the behavior of the loop.

- Step 7. If the carrier seems to lock and stops sweeping, then check the Carrier and FEC Synchronization Status register (Group 3, APR 9) for the status. All flags should be set to one when the carrier and clock are locked.
- Step 8. If all of the flags in the Carrier and FEC Synchronization Status register are set to 1, then set the CAR\_SW and CAR\_OPEN bits in the Carrier Loop Configuration register r to b00, This turns off the sweep.

B.3This section shows an example of how to configure the QPSK Demodu-<br/>lator section of the L64704 through its microcontroller interface. This<br/>example configuration is optimized for fixed rate operation with the fol-<br/>lowing parameters:B.3This section shows an example of how to configure the QPSK Demodu-<br/>lator section of the L64704 through its microcontroller interface. This<br/>example configuration is optimized for fixed rate operation with the fol-<br/>lowing parameters:

- Transmission Rate: 42.6 Mbps (21.3 Mbaud)
- ◆ Clock VCO: 42.6 MHz (1 MHz/V)
- ◆ Carrier VCO: 479.75 MHz (1.8 MHz/V)
- Xtal OSC: 10.00 MHz
- ◆ ADC: Input: 1.0 V p-to-p
- DC offset control: not used

B.3.1 Programming the L64704 QPSK Demodulator Registers This subsection describes how to program each of the L64704's registers. The microcontroller addresses these registers as described in Section 3.1, "L64704 Register Overview."

**Group 4, APR 14** – Set the lower four bits in the Clock Loop Control 1 register as shown in the following table.

| Bits \$ | Setting | Acronym          | Meaning                                |
|---------|---------|------------------|----------------------------------------|
| 1:0     | 0       | CLK_DR[1:0]      | No decimation, oversampling ratio = 2. |
| 2       | 0       | CLK_VCO_SWAP     | CLK outputs not swapped.               |
| 3       | 0       | CLK_LCF_Suppress | AFC enabled.                           |

Set Group 4, APR 14 to 0x00.

Group 4, APR 15 - The recommended value for CLK\_RP[3:0] is 10.

Set Group 4, APR 15 to 0x0A.

**Group 4, APR 16-17** – The recommended value for CLK\_NF[15:0] is 43622, as computed from Equation 5.1 on page 5-6:

 $CLK\_NF = \frac{42.6 \times 10 \times 1024}{10} = 43622$ 

Set APR 16 to 0xAA and APR 17 to 0x66.

**Group 4, APR 18** – The recommended value for CLK\_RATIO[2:0] is 0 for only 2 samples/symbol.

Set Group 4, APR 18 to 0x00.

**Group 4, APR 19** – PWR\_REF[7:0] = 84 is the recommended value if L = 1. As discussed in Section 5.7.1, "ADC Range and Power Reference," 2*R* is the ADC range p-to-p and 2*S* is the input signal range p-to-p on the I and Q channels. The ratio S:R must be 1:1.7 when PWR\_REF = 84.

$$\frac{S}{R} = \frac{1}{1.7}$$

So, in this case the input signal level is

$$S = \frac{0.5 \times 1.0}{1.7} = 0.29$$
.

If the AGC loop is not connected, ensure that the L64704 is sending the correct output power.

Set Group 4, APR 19 to 0x54.

**Group 4, APR 20** – Set PWR\_BW according to Table 5.5 on page 5-23. PWR\_BW[1:0] = 0 in this example.

Set Group 4, APR 20 to 0x00.

Group 4, APR 21 - The recommended value for SCALE[7:0] is 158.

Set Group 4, APR 21 to 0x9E.

Group 4, APR 22 - Set SNR\_THS[7:0] = 0x1F.

Set Group 4, APR 22 to 0x1F.

**Group 4, APR 23** – Set CAR\_OFFSET[7:0] = 0.

Set Group 4, APR 23 to 0x00.

Group 4, APR 24 - The recommended value for CAR\_RP is 8.

Set Group 4, APR 24 to 0x08.

**Group 4, APR 25** – Set CAR\_KP to 64. The CAR\_KP register has a limited range between 30 and 127; values above 127 do not work.

For fixed rate operation:

 Select B<sub>L</sub> (the equivalent noise BW) based on the criteria shown in Equation B.2 and Table B.4:

Equation B.2

 $B_{I} = 0.001 \times BaudRate$ 

$$\mathsf{B}_L = \frac{\omega_n}{2} \bigg( \xi + \frac{1}{1+4\xi} \bigg)$$

Where  $\xi$  is the loop's damping,  $\omega_n$  is in rad/s, and  $B_L$  is in Hz.

| Table B.4<br>$\omega_n$ for Fixed Rate | Data Rate (Mbaud) | ω <sub>n</sub> (kilorad/s/volt) |
|----------------------------------------|-------------------|---------------------------------|
| Operation<br>(Damping = 1)             | 10                | 16                              |
| · · · · /                              | 20                | 32                              |
|                                        | 30                | 48                              |

- Set CAR\_KP to 0X40. Because of the limited range of CAR\_KP (30 and 127) This value places it in the middle of the range.
- ♦ Based on Equation 5.11 on page 5-18,

$$R_{CAR}C_{CAR} = \frac{3.3K_DK_{CARVCO}}{CAR_KP\omega_n^2}$$

 $K_D$  is the Phase Detector Gain and it depends on whether the DDML or the NDAML estimator is selected (CON\_SEL; Group 4, APR 35). Figure 5.9 on page 5-19 shows the Gains of the two phase detectors as a function of C/N.

 $K_D$  is about 10 for C/N = 4 dB (Channel Eb/No = 1 dB).

Set  $K_D$  = 10,  $K_{CARVCO}$  = 1.8 MHz/V = 11.3 Mrad/s/V and  $\omega_n$  = 32 K Rad/s/v.

$$R_{CAR}C_{CAR} = \frac{3.3 \times 10 \times 1.8 \times 10^{6} \times 2\pi}{64(32 \times 10^{3})^{2}}$$

Therefore in this example,  $R_{CAR}C_{CAR} = 10$  ms.

**Group 4, APR 26** – The recommended value for CAR\_KD is 207, based on Equation 5.11 on page 5-18,

$$CAR\_KD = \frac{\zeta}{2\omega_n T} = 207$$

where  $\zeta = 1$ ,  $\omega_n = 51.5$  krad/s/V, and T =  $2/42.6 \times 10^6$ .

Set Group 4, APR 26 to 0xCF.

**Group 4, APR 27** – The recommended value for CAR\_THSL[7:0] is 31 when FP\_LOCK\_LEN (Group 4, APR 35) is set to 0. Otherwise, set it according to the following table:

| FP_LOCK_LEN | CAR_THSL[7:0] | Signal to Noise Ratio |
|-------------|---------------|-----------------------|
| 0           | 31            | Low Eb/No             |
| 1           | 72            | High Eb/No            |

Set Group 4, APR 27 to 0x1F.

**Group 4, APR 28** – The recommended starting point for CAR\_SWR[7:0] is 33. Experiment with other values to optimize performance.

Set Group 4, APR 28 to 0x21.

**Group 4, APR 29-30** – The recommended value for CAR\_USWL[13:0] is 12301, assuming that the prescaler divides the frequency of the carrier VCO by 32 and that jitter is  $\pm$ 1 MHz.

CAR\_USWL = ((479.5 + 1) / 32) x ((8 x 1024) / 10) = 12301

Set APR 29 to 0x30 and APR 30 to 0x0D.

**Group 4, APR 31-32** – Set CAR\_LSWL to 12250, based on the following equation:

CAR\_LSWL = ((479.5 - 1) / 32) x ((8 x 1024) / 10) = 12250

Set APR 31 to 0x2F and APR 32 to 0xDA.

**Group 4, APR 33** – Set the Carrier Loop Configuration register to 0x25 when this register's bits are set as shown in the following table.

| Bit | Setting | Meaning |
|-----|---------|---------|
|-----|---------|---------|

|   | - |                                                      |
|---|---|------------------------------------------------------|
| 0 | 1 | Carrier sweep on                                     |
| 1 | 0 | CAR_OPEN. Set to one only to get out of false lock   |
| 2 | 1 | 0 = DDML, 1 = NDAML                                  |
| 3 | 0 | 0 = Sigma Delta, 1 = 6-bit output to DAC             |
| 4 | 0 | CAR_VCO1N/P, 0 = active, 1 = 3-state                 |
| 5 | 1 | CAR_VCO2N/P, 0 = active, 1 = 3-state                 |
| 6 | 0 | CAR_VCOxN/P output polarity, 0 = normal, 1 = swapped |
| 7 | 0 | Sweep Direction, 0 = normal, 1 = swapped             |

Together, bits 6 and 7 may be set to any one of four values. Use the following guidelines for programming these bits:

- 1. If the carrier frequency sweep gets stuck at the upper or lower rail, change the polarity of the bits until the sweep works correctly.
- 2. If the carrier is locked but the constellation is rotated by 45 degrees, reverse the polarity of each bit.

Set Group 4, APR 33 to 0x25. When the Carrier and FEC Synchronization Status register (Group 3, APR 9) indicates a lock, change it to 0x24.

**Group 4, APR 34 –** Set to 0 – All of the bits in this register must be set to 0 for proper operation.

**Group 4, APR 35** – The settings in the Decoder Configuration register are application dependent. Do not use the SNR estimator in this example.

**Group 3, APR 6-7** – CAR\_VCOF[13:0] = shows the result of the VCO frequency measurement. The resolution of the received value depends on the prescaler as shown in the following table.

| Prescaler Divisor | ∆f <sub>VCO</sub> (kHz) |
|-------------------|-------------------------|
| 16                | 19.5                    |
| 32                | 39                      |

Group 3, APR 9 - STATUS[2:0] is a read-only register.

Table B.5 shows a register map of the register used to configure the BPSK/QPSK demodulator portion of the L64704, and Table B.6 provides a summary of all of the programming information supplied above.

### Table B.5 Group 4 Decoder Register Map

| APR[5:0] | D7                | D6               | D5              | D4              | D3                   | D2                           | D1            | DO       |
|----------|-------------------|------------------|-----------------|-----------------|----------------------|------------------------------|---------------|----------|
| 14       | SYNC/<br>SCLK     | Reserved         | Set to 0        | F_OUT_<br>HiZ   | CLK_LCF_<br>SUPPRESS | CLK_VCO_<br>SWAP CLK_DR[1:0] |               |          |
| 15       | Set to 0          | PCLK_BP          | Set to 0        | PD              |                      | CLK                          | _RP           |          |
| 16       |                   |                  |                 | CLK_N           | IF[15:8]             |                              |               |          |
| 17       |                   |                  |                 | CLK_N           | NF[7:0]              | -                            |               |          |
| 18       |                   |                  | Reserved        |                 |                      | С                            | LK_RATIO[2:   | 0]       |
| 19       |                   |                  |                 | PWR_F           | REF[7:0]             |                              |               |          |
| 20       |                   |                  | Reserved        |                 |                      | INT_DC                       | PWR_E         | 3W[1:0]  |
| 21       |                   |                  | Scale Fa        | ctor for DEM    | I, DEMQ, SC          | CALE[7:0]                    |               |          |
| 22       |                   |                  | SNR Es          | timator Three   | shold, SNR_          | THS[7:0]                     |               |          |
| 23       |                   | Car              | rier Loop DC    | Offset Comp     | pensation, C/        | AR_OFFSET[                   | [7:0]         |          |
| 24       |                   | Rese             | erved           |                 | Carrier              | Reference P                  | Period, CAR_I | RP[3:0]  |
| 25       |                   |                  | Carrier Loo     | p Filter Gain   | (P Term), C          | AR_KP[7:0]                   |               |          |
| 26       |                   |                  | Carrier Loo     | p Filter Gain   | (D Term), C          | AR_KD[7:0]                   |               |          |
| 27       |                   |                  | Carrier Lock    | Detector Th     | reshold, CAF         | R_THSL[7:0]                  |               |          |
| 28       |                   |                  | Carrie          | er Sweep Ra     | te, CAR_SW           | R[7:0]                       |               |          |
| 29       | Rese              | erved            |                 | Carrier Up      | per Sweep L          | _imit, CAR_U                 | SWL[13:8]     |          |
| 30       |                   |                  | Carrier U       | oper Sweep      | Limit, CAR_L         | JSWL[7:0]                    |               |          |
| 31       | Rese              | erved            |                 | Carrier Lo      | wer Sweep I          | _imit, CAR_L                 | SWL[13:8]     |          |
| 32       |                   |                  | Carrier Lo      | ower Sweep      | Limit, CAR_L         | _SWL[7:0]                    |               |          |
| 33       | CAR_SWP_<br>SWAP  | CAR_VCO_<br>SWAP | CAR_VCO2<br>N/P | CAR_VCO1<br>N/P | CAR_OUT_<br>SEL      | CAR_PED_<br>SEL              | CAR_OPEN      | CAR_SW   |
| 34       | Set to 0 Reserved |                  |                 |                 |                      |                              |               |          |
| 35       | SNR_EST           | CON_SEL          | Set to 0        | FP_LOCK_<br>LEN | PWRP                 | Set                          | to 0          | I_FORMAT |
| 36       | Rese              | erved            | Externa         | al Control Ou   | tput Bits, XC        | TR[3:0]                      | DEMOD_<br>RST | FEC_RST  |

# Table B.6 Group 4 Decoder Registers Actual Configuration

| APR | D7 | D6 | D5 | D4         | D3       | D2 | D1 | D0 | HEX |
|-----|----|----|----|------------|----------|----|----|----|-----|
| 14  | 0  | 0  | 0  | 0          | 0        | 0  | 0  | 0  | 00  |
| 15  | 0  | 0  | 0  | 0          | 1        | 0  | 1  | 0  | 0A  |
| 16  | 1  | 0  | 1  | 0          | 1        | 0  | 1  | 0  | AA  |
| 17  | 0  | 1  | 1  | 0          | 0        | 1  | 1  | 0  | 66  |
| 18  | 0  | 0  | 0  | 0          | 0        | 0  | 0  | 0  | 00  |
| 19  | 0  | 1  | 0  | 1          | 0        | 1  | 0  | 0  | 54  |
| 20  | 0  | 0  | 0  | 0          | 0        | 0  | 0  | 0  | 00  |
| 21  | 1  | 0  | 0  | 1          | 1        | 1  | 1  | 0  | 9E  |
| 22  | 0  | 0  | 0  | 1          | 1        | 1  | 1  | 1  | 1F  |
| 23  | 0  | 0  | 0  | 0          | 0        | 0  | 0  | 0  | 00  |
| 24  | 0  | 0  | 0  | 0          | 1        | 0  | 0  | 0  | 08  |
| 25  | 0  | 1  | 0  | 0          | 0        | 0  | 0  | 0  | 40  |
| 26  | 1  | 1  | 0  | 0          | 1        | 1  | 1  | 1  | CF  |
| 27  | 0  | 0  | 0  | 1          | 1        | 1  | 1  | 1  | 1F  |
| 28  | 0  | 0  | 1  | 0          | 0        | 0  | 0  | 1  | 21  |
| 29  | 0  | 0  | 1  | 1          | 0        | 0  | 0  | 0  | 30  |
| 30  | 0  | 0  | 0  | 0          | 1        | 1  | 0  | 1  | 0D  |
| 31  | 0  | 0  | 1  | 0          | 1        | 1  | 1  | 1  | 2F  |
| 32  | 1  | 1  | 0  | 1          | 1        | 0  | 1  | 0  | DA  |
| 33  | 0  | 0  | 1  | 0          | 0        | 1  | 0  | 1  | 25  |
| 34  | 0  | 0  | 0  | 0          | 0        | 0  | 0  | 0  | 00  |
| 35  |    |    | A  | pplication | Dependar | nt |    |    | N/A |
| 36  |    |    | A  | pplication | Dependar | nt |    |    | N/A |

# B.3.2 RC Values for Clock Loop

Table B 7

B-16

To compute the RC values for the clock loop using Equation 5.3 and Equation 5.4 on page 5-7, choose the natural frequency  $\omega_n$  according to Table 5.2 and set the damping factor  $\zeta$  to 1 for fixed rate operation.

This example uses the following values for each parameter:  $\zeta = 1$ , M = 2,  $\omega_n = 3900$ , and  $K_{VCO} = 1$  MHz/V (assuming  $K_D = 0.92$ ). From Equation 5.3 and Equation 5.4, the RC values in this example are:

$$R_{CLK2}C_{CLK} = \frac{2\zeta}{\omega_n} = 5 \times 10^{-4}$$
 seconds

$$R_{CLK1}C_{CLK} = \frac{1}{\omega_n^2} \times \frac{K_D 2\pi K_{VCO}}{2\pi M}$$
$$= \frac{1}{(3.9 \times 10^3)^2} \times \frac{(0.92)2\pi \times 10^6}{2\pi (2)}$$
$$= 30 \times 10^{-3} \text{seconds}$$

Choose: 
$$C_{CLK} = 1$$
 F,  $R_{CLK1} = 30$  k,  $R_{CLK2} = 510\Omega$ .

**B.3.3** Table B.7 gives typical ranges for the clock and carrier VCO gains. The values depend on whether your application requires fixed rate or variable rate operation.

| Typical Clock and | External Loop | VCO Gain (kHz/V) |  |  |
|-------------------|---------------|------------------|--|--|
| Carrier VCO Gains | Clock         | 100 to 2000      |  |  |
|                   | Carrier       | 750 to 2500      |  |  |

B.3.4 When the system functions at low baud rates (generally below 5 Mbaud), connect the Phase Error Detector outputs to an external DAC, and feed the voltage level from the output of the DAC to one of the loop filters as shown in Figure 5.10.

The lower two bits of the Phase Error Detector outputs are brought out on the CAR\_PED0 and CAR\_PED1 pins. The upper four bits of the Phase detector output are shared with the four CAR\_VCO pins as shown in Table B.8:

| Table B.8<br>CAR_PED Output | CAR_OUT_SEL Bit |          |  |  |
|-----------------------------|-----------------|----------|--|--|
| Butput Pin Name             | 0               | 1        |  |  |
| CAR_PED0                    | CAR_PED0        | CAR_PED0 |  |  |
| CAR_PED1                    | CAR_PED1        | CAR_PED1 |  |  |
| CAR_VCO1P                   | CAR_VCO1P       | CAR_PED2 |  |  |
| CAR_VCO2P                   | CAR_VCO2P       | CAR_PED3 |  |  |
| CAR_VCO1N                   | CAR_VCO1N       | CAR_PED4 |  |  |
| CAR_VCO2N                   | CAR_VCO2N       | CAR_PED5 |  |  |

To enable the Phase Error Detector outputs, set the CAR\_PED\_SEL bit in the Carrier Loop Configuration register (Group 4, APR 33) to 1.

- 1. Choose CAR\_KD.
- 2. Choose ζ.
- 3. Choose ω<sub>n.</sub>
- 4. Calculate R<sub>2</sub>, R<sub>1</sub>, and C from the following equations:

$$\zeta = \frac{R_2 C \omega_n}{2} , \ \omega_n = \sqrt{\frac{K_D K_{carvco} (CAR_KD) (ADR)}{R_1 C \times 8192}}$$

where ADR is one side of the DAC range. For example, if the DAC output range is  $\pm 1$  volt, then ADR = 1.

$$\frac{2b_2}{2N-(1+\beta)} \le \frac{1}{T} \le \min\left(\frac{2b_1}{1+\beta}, \frac{f_{max}}{N}\right).$$

| B.4<br>Configuring the       | This section presents the steps required to configure the L64704 to the DVB specifications. The following pages continue the initialization exam- |                        |  |  |  |  |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--|--|--|--|
| L64704 FEC<br>Decoder to the | ple for the following case:                                                                                                                       |                        |  |  |  |  |
| DVB                          | <ul> <li>Transmission Rate:</li> </ul>                                                                                                            | 42.6 Mbps (21.3 Mbaud) |  |  |  |  |
| Specifications               | <ul> <li>QPSK Clock VCO:</li> </ul>                                                                                                               | 42.6 MHz               |  |  |  |  |

- Viterbi Rate: 1/2
- ◆ ICLK: 21.3 MHz
- OCLK: 21.3 MHz

Table B.9 is the address map for the group 4 registers. Table B.10 presents the proper configuration for the above system parameters.

## Table B.9 Group 4 Register Map

| APR | D7                                                     | D6           | D5               | D4            | D3                                                  | D2            | D1          | DO             |
|-----|--------------------------------------------------------|--------------|------------------|---------------|-----------------------------------------------------|---------------|-------------|----------------|
| 0   | Set to 1                                               | Set to 0     |                  | PLL_N         |                                                     |               |             |                |
| 1   | Set to 0                                               | Set to 0     |                  |               | PLL                                                 | S             |             |                |
| 2   | IMQ                                                    | Set to 1     | QB               |               |                                                     | PLL_T         |             |                |
| 3   | Viterb                                                 | oi Code Rate | e[2:0]           | TEI           | Set to 0                                            | Set to 0      | PLL_N       | <i>I</i> [1:0] |
| 4   |                                                        |              | Viterbi Ma       | ax Data Bit ( | Count 1, VN                                         | IDC1[7:0]     |             |                |
| 5   |                                                        | Vite         | erbi Max Da      | ta Bit Count  | 2, VMDC2[                                           | 7:0], Low B   | yte         |                |
| 6   | Viterbi Max Data Bit Count 2, VMDC2[15:8], Middle Byte |              |                  |               |                                                     |               |             |                |
| 7   |                                                        | Viter        | bi Max Data      | Bit Count 2   | 2, VMDC2[2                                          | 3:16], High l | Byte        |                |
| 8   |                                                        |              | Viterbi          | Maximum B     | it Error Cou                                        | nt[7:0]       |             |                |
| 9   |                                                        | _            | S                | ynchronizati  | on Word[7:0                                         | )]            | _           |                |
| 10  | BER                                                    |              |                  | Reserved      | _                                                   |               | L[1         | :0]            |
| 11  | BF                                                     | Set to 0     | Sync Stat<br>SSS |               | Sync States Acq. Sync States T<br>SSA[1:0] SST[1:0] |               |             |                |
| 12  | BPS[2:0]                                               |              |                  | Set to 0      | OF                                                  | Output        | Selector, O | S[2:0]         |
| 13  | PLL_RESET                                              |              |                  |               |                                                     |               |             |                |

## Table B.10 Group 4 Actual Configuration

| APR | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | HEX |
|-----|----|----|----|----|----|----|----|----|-----|
| 0   | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 82  |
| 1   | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 04  |
| 2   | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 0  | C2  |
| 3   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 00  |
| 4   | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 40  |
| 5   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 00  |
| 6   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 00  |
| 7   | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0F  |
| 8   | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 20  |
| 9   | 0  | 1  | 0  | 0  | 0  | 1  | 1  | 1  | 47  |
| 10  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 01  |
| 11  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 81  |
| 12  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 05  |
| 13  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 00  |

The following paragraphs describe how to program each of the L64704's registers.

From Table 4.2 on page 4-8 for rate 1/2 ICLK = PCLK = 21.3 MHz, select the eighth row from the top: PLL\_N = 2, PLL\_S = 4, PLL\_T = 2, PLL\_M = 0.

**Group 4, APR 0** – Set bit D7 to 1 and set bit D6 to 0. Based on line 8 from Table 4.2, set the PLL\_N field to 2.

Set Group 4, APR 0 to 0xC2.

**Group 4, APR 1** – Set bits D7 and D6 to 0. Based on line 8 from Table 4.2, set PLL\_S to 4.

Set Group 4, APR 1 to 0x04.

**Group 4, APR 2** – Set IMQ to either 0 or 1, the D6 bit to 1, and QB to 0 for QPSK. Based on line 8 from Table 4.2, set PLL\_T to 2.

Set Group 4, APR 2 to 0x42.

**Group 4, APR 3** – Set VCR to 0 for rate 1/2, TEI to 0 or 1, TM to 0. Based on line 8 from Table 4.2, set PLL\_M to 0.

Set Group 4, APR 3 to 0x00.

**Group 4, APR 4** – From the graphs starting with Figure 7.6 on page page 7-9, choose a value between the in-sync and out of sync curves. A value of 20% is a reasonable choice for operation at Eb/No of 3.5 and above. Based on this choice, set VMDC1 to 64 (0x40). This value selects a window of size  $64 \times 256 = 16,384$  bits.

Set Group 4, APR 4 to 0x40.

**Group 4, APR 5-7** – VMDC2 selects a second window. This value controls the window size over which Viterbi Errors are counted. It is used for calculating the BER, not for the auto-synchronization that is controlled by VMDC1. In this example, choose a window size of  $3.932 \times 10^6$  bits = VMDC2 x 4. Other values may work as well.

Set Group 4, APR 5 to 0x00, set Group 4, APR 6 to 0x00, and set Group 4, APR 7 to 0x0F.

**Group 4, APR 8** – VMBEC is the second parameter that controls the Viterbi auto-sync. Select a ratio of 20% from the value of VMDC1 x 256.  $0.2 \times 16,384 = 3277$ . Program the value of VMBEC to (3277 - 32) / 128 = 25 = 0x19.

For lower Eb/No, a ratio of 25% is better. In this case, the calculation is:  $0.25 \times 16,384 = 4096$ . So, the value is 32 (0x20).

Set Group 4, APR 8 to 0x20.

Group 4, APR 9 - The DVB sync word is 0x47.

Set Group 4, APR 9 to 0x47.

**Group 4, APR 10** – In this example, select a value of 1. See the description of Group 4, APR 10 on page 3-33.

Set Group 4, APR 10 to 0x01.

**Group 4, APR 11** – In this example, select SSS = 0 to observe the Viterbi sync status. See the description of Group 4, APR 11 on page 3-34.

Set Group 4, APR 11 to 0x81.

**Group 4, APR 12** – This example does not use the Viterbi bypass mode, so BPS has no effect here. Set IS to 0, OF to 0, and OS to 5 to start debugging by looking at the Viterbi output.

Set Group 4, APR 12 to 0x05.

**Group 4, APR 13** – Write any value to Group 4, APR 13 to reset the PLL module.

Set Group 4, APR 13 to 0x00.

# Appendix C Oscillator Cells

This appendix describes the LSI Logic oscillator cells used in the L64704. These cells are designed to be used with external components to form an oscillator circuit.

C.1 Oscillator cells exist at LSI Logic in both Channel-Free Arrays and Cell-Introduction Based ASIC technologies. These cells have been designed to work with external crystals and RLC components. Passive component values on semiconductor ICs are far too variable to provide the accuracy required to obtain stable oscillation frequencies.

The simplest oscillator consists of an inverting gate with the output connected to the input as shown in Figure C.1.

Figure C.1 Simplest Oscillator

Most designers avoid this type of oscillator, because its frequency is too dependent on wafer processing variations, bias voltage values, and temperature effects. The oscillator in Figure C.1 is most commonly found when unwanted, positive feedback paths creep into a design, causing the apparent effect shown.

| C.2<br>Requirements        | The following requirements must be met for the oscillator circuits to operate properly:                                                                                                                                                                                         |  |  |  |  |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| For Oscillator<br>Circuits | <ul> <li>The V<sub>DD</sub> ramp time must be greater than or equal to 1 millisecond<br/>to start up the oscillator.</li> </ul>                                                                                                                                                 |  |  |  |  |
|                            | <ul> <li>The EN pin must be tied to V<sub>DD</sub>. This means that the EN pin cannot<br/>be used to enable or disable the oscillator.</li> </ul>                                                                                                                               |  |  |  |  |
| C.3<br>0 to 20 MHz         | LSI Logic's OSCXX cells are intended to be used with external compo-<br>nents to form an oscillator circuit, such as the one shown in Figure C.2.                                                                                                                               |  |  |  |  |
| Crystal<br>Oscillator      | The recommended crystal is an AT-cut crystal. The inherent characteristics of such a crystal produce a fundamental frequency ( $f_F$ ) less than 20 MHz and third overtone frequencies ( $f_{3OT}$ ) between 20 MHz and 60 MHz. Oscillation begins when the power is turned on. |  |  |  |  |
|                            | Crystals by nature are usually immune to power supply and temperature variations, thereby providing very stable frequencies over the $V_{DD}$ and $T_A$ ranges of the ASIC devices. In addition, the duty cycle of the output                                                   |  |  |  |  |

waveform for the circuit in Figure C.2 approaches the ideal of 50%, producing a clean symmetrical waveform.

Figure C.2 Pierce Crystal Oscillator Circuit



1.  $R_{DC}$  = the DC resistance of the crystal.  $R_{DC}$  should be in the range from 1 to 5 Meg ohms.

For frequencies within the range of the crystal's fundamental frequency (0 to 20 MHz), the circuit in Figure C.2 works with the component values given in Table C.1. For the capacitors:

$$C_1 = C_2 = 2 \times C_L - C_B$$

where  $C_L$  = Crystal Parameter (typically 32 pF) and  $C_B$  = board connection capacitance (typically 3 pF).

The basis for the values in Table C.1 comes from the relationship:

 $f_F \cong 1/(2\pi R_2 \times C_2)$ 

where  $f_{\mathsf{F}}$  is the desired frequency of oscillation (shown on the crystal itself).

| Table C.1<br>Component Values | Frequency | C <sub>1</sub> = C <sub>2</sub> (pF) | R <sub>2</sub> (Ω) |
|-------------------------------|-----------|--------------------------------------|--------------------|
| for the<br>Circuit Shown in   | 2 MHz     | 61                                   | 1000               |
| Figure C.2                    | 5 MHz     | 61                                   | 500                |
| 0                             | 10 MHz    | 61                                   | 250                |
|                               | 20 MHz    | 61                                   | 100                |

# **C.4** Higher Frequency Oscillators

Figure C.3

A Third Overtone

**Oscillator Circuit** 

Frequency ranges between 20 MHz and 60 MHz can be obtained with the circuit shown in Figure C.3.



1.  $R_{DC}$  = the DC resistance of the crystal.  $R_{DC}$  should be in the range from 1 to 5 Meg ohms.

Values are chosen for the components in Figure C.3 based on the following considerations:

 $C_1 = C_2 = 2 \times C_I - C_B$ 

where  $C_L$  = Crystal Parameter (typically 22 to 25 pF) and  $C_B$  = board connection capacitance (typically 3 pF).

$$f \cong 1/(2\pi R_2 \times C_2)$$
 and

$$f \cong 3/(4\pi \sqrt{L_2 \times C_2})$$

where f is the desired frequency specified on the crystal. Table C.2 shows typical component values for a range of frequencies.

| Table C.2<br>Component Values | Frequency | C <sub>2</sub> (pF) | R <sub>2</sub> (Ω) | <b>L<sub>2</sub>(μΗ)</b> |
|-------------------------------|-----------|---------------------|--------------------|--------------------------|
| for the Circuit<br>Shown in   | 25 MHz    | 47                  | 120                | 1.9                      |
| Figure C.3                    | 32 MHz    | 47                  | 100                | 1.2                      |
| 5                             | 40 MHz    | 47                  | 80                 | 0.8                      |
|                               | 50 MHz    | 47                  | 60                 | 0.5                      |

# C.5 Low Frequency Oscillation (kHz Range)

A circuit that can be used to reliably obtain a lower frequency oscillation is shown in Figure C.4. This circuit should be used for the 0 to 100 kHz range of frequencies.

Figure C.4 A Low Frequency Range (kHz) Oscillator Circuit



1.  $R_{DC}$  = the DC resistance of the crystal.  $R_{DC}$  should be in the range from 1 to 5 Meg ohms.

For the capacitors:

 $C_1 = C_2 = 2 \times C_L - C_B$ 

where  $C_L$  = Crystal Parameter (typically 32 pF) and  $C_B$  = board connection capacitance (typically 3 pF).

The basis for the values in Table C.3 comes from the relationship:

 $f_F \cong 1/(2\pi R_2 \times C_2)$ 

where  $f_{\mathsf{F}}$  is the desired frequency of oscillation (shown on the crystal itself).

| Table C.3<br>Component Values<br>for the Circuit<br>Shown in<br>Figure C.4 | Frequency | C <sub>2</sub> (pF) | $R_2$ (k $\Omega$ ) |  |  |
|----------------------------------------------------------------------------|-----------|---------------------|---------------------|--|--|
|                                                                            | 20 kHz    | 61                  | 100                 |  |  |
|                                                                            | 50 kHz    | 61                  | 40                  |  |  |
| 0                                                                          | 75 kHz    | 61                  | 25                  |  |  |
|                                                                            | 100 kHz   | 61                  | 15                  |  |  |

# **Customer Feedback**

We would appreciate your feedback on this document. Please copy the following page, add your comments, and fax it to us at the address on the following page.

If appropriate, please also fax copies of any marked-up pages from this document.

Important: Please include your name, phone number, fax number, and company address so that we may contact you directly for clarification or additional information.

Thank you for your help in improving the quality of our documents.

| Reader's | Fax your comments to:                                                                                                                                                                                                                                          |             |       |           |   |  |  |  |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------|-----------|---|--|--|--|
| Comments | LSI Logic Corporation<br>Publications Department<br>M/S F-112<br>Fax: 408.433.4333<br>Please tell us how you rate this document: <i>L64704 Satellite Decoder</i><br><i>Technical Manual.</i> Place a check mark in the appropriate blank for each<br>category. |             |       |           |   |  |  |  |
|          |                                                                                                                                                                                                                                                                |             |       |           |   |  |  |  |
|          | Completeness of information<br>Clarity of information<br>Ease of finding information<br>Technical content<br>Usefulness of examples and<br>illustrations<br>Overall manual                                                                                     |             |       |           |   |  |  |  |
|          | What could we do to improve                                                                                                                                                                                                                                    | e this docu | ment? |           |   |  |  |  |
|          | If you found errors in this document, please specify the error and page number. If appropriate, please fax a marked-up copy of the page(s).                                                                                                                    |             |       |           |   |  |  |  |
|          |                                                                                                                                                                                                                                                                |             |       |           |   |  |  |  |
|          | Please complete the information below so that we may contact you directly for clarification or additional information.                                                                                                                                         |             |       |           |   |  |  |  |
|          | Name                                                                                                                                                                                                                                                           |             |       | Date _    |   |  |  |  |
|          | Telephone                                                                                                                                                                                                                                                      |             | Fax   |           |   |  |  |  |
|          | Title                                                                                                                                                                                                                                                          |             |       |           |   |  |  |  |
|          | Department                                                                                                                                                                                                                                                     |             |       | Mail Stop | o |  |  |  |
|          | Company Name                                                                                                                                                                                                                                                   |             |       |           |   |  |  |  |
|          | Street                                                                                                                                                                                                                                                         |             |       |           |   |  |  |  |
|          | City, State, Zip                                                                                                                                                                                                                                               |             |       |           |   |  |  |  |
|          |                                                                                                                                                                                                                                                                |             |       |           |   |  |  |  |

Customer Feedback

# **U.S. Distributors** by State

A. E. Avnet Electronics W. E. Wyle Electronics Alabama Huntsville Tel: 205.837.8700 AF W. E. Tel: 800.964.9953 Alaska Tel: 800.332.8638 A. E. Arizona Phoenix A. E. Tel: 602.736.7000 W. E. Tel: 800.528.4040 Tucson A. E. Tel: 520.742.0515 California Irvine Tel: 949.789.4100 A. E. W. E. Tel: 800.626.9953 Los Angeles Tel: 818.594.0404 A. E. W. E. Tel: 800.288.9953 Sacramento A.E. Tel: 916.632.4500 W. E. Tel: 800.627.9953 San Diego Tel: 619.571.7540 AF W. E. Tel: 800.829.9953 San Jose Tel: 408.435.3500 A. E. Santa Clara Tel: 800.866.9953 W. E. Woodland Hills A. E. Tel: 818.594.0404 Colorado Denvei

Tel: 303.790.1662 A. E. Tel: 800.933.9953 W. E.

#### Connecticut

Chesire Tel: 203.271.5700 AF Wallingford W. E. Tel: 800.605.9953

Delaware North/South

Tel: 800.526.4812 A. E. Tel: 800.638.5988

#### Florida

Fort Lauderdale A. E. Tel: 305.484.5482 W. E. Tel: 800.568.9953 Orlando Tel: 407.657.3300 A. E. W. E. Tel: 407.740.7450 Tampa W. E. Tel: 800.395.9953 St. Petersburg Tel: 813.507.5000 A. E. Georgia Atlanta A. E. Tel: 770.623.4400 Tel: 800.876.9953 W. E.

#### Hawaii A. E.

Tel: 800.851.2282 Idaho A. E. Tel: 801.266.2022

#### Illinois

North/South A. E. Tel: 847.797.7300 Tel: 314.291.5350 Chicago W. E. Tel: 800.853.9953

#### Indiana

Indianapolis Tel: 317.575.3500 A. E. W. E. Tel: 888.358.9953

#### lowa

Cedar Rapids Tel: 319.393.0033 A. E.

#### Kansas

Kansas City A. E. Tel: 913.663.7900

#### Kentucky

Central/Northern/ Western A. E. Tel: 800.984.9503 Tel: 800.767.0329 Tel: 800.829.0146

#### Louisiana

North/South A. E. Tel: 800.231.0253 Tel: 800.231.5575

#### Maine

A. E. Tel: 800.272.9255

#### Maryland

Baltimore A. E. Tel: 410.720.3400 WF Tel: 800.863.9953

#### Massachusetts

Boston Tel: 978.532.9808 A. E. W. E. Tel: 800.444.9953

#### Michigan

Detroit A. E. Tel: 313.416.5800 W. E. Tel: 888.318.9953 Grandville A. E. Tel: 616.531.0345

#### Minnesota

Minneapolis A. E. Tel: 612.881.2600 W. E. Tel: 800.860.9953

#### Mississippi . Tel: 800.633.2918 A. E.

Missouri

#### St. Louis A. E. Tel: 314.291.5350

Montana

#### Tel: 800.526.1741 A. E.

Nebraska

#### A. E. Tel: 800.332.4375

Nevada Las Vegas

#### Tel: 800.528.8471 AF W. E. Tel: 702.765.7117

New Hampshire

Tel: 800.272.9255 A. E.

#### New Jersev

North/South A. E. Tel: 201.515.1641 Tel: 609.222.6400 Oradell W. E. Tel: 201 261 3200 Pine Brook W. E. Tel: 800.862.9953 New Mexico Albuquerque Tel: 505.293.5119 A. E. New York

#### Long Island

A.E. Tel: 516.434.7400 W. E. Tel: 800.861.9953 Rochester A. E. Tel: 716.475.9130 W. E. Tel: 800.319.9953 Syracuse Tel: 315.453.4000 AF

#### North Carolina

Raleigh A. E. Tel: 919.872.0712 WF Tel: 800.560.9953

#### North Dakota Tel: 800.829.0116 A. E.

Ohio Cleveland Tel: 216.498.1100 A. E.

W. E. Tel: 800.763.9953 Dayton A. É. Tel: 614.888.3313 W.E. Tel: 800.763.9953

#### Oklahoma

Tulsa A. E. Tel: 918.459.6000

#### Oregon

Portland Tel: 503.526.6200 A. E. WF Tel: 800.879.9953

#### Pennsylvania

Pittsburgh A. E. Tel: 412.281.4150 Philadelphia A. E. Tel: 800.526.4812 W. E. Tel: 800.871.9953

#### Rhode Island 800.272.9255 AF

South Carolina A. E. Tel: 919.872.0712

```
South Dakota
A. E.
         Tel: 800.829.0116
```

#### Tennessee

East/West A. E. Tel: 800.241.8182 Tel: 800.633.2918

#### Texas

Austin A. E. Tel: 512.219.3700 W. E. Tel: 800.365.9953 Dallas AF Tel: 214 553 4300 W. E. Tel: 800.955.9953 El Paso A. E. Tel: 800.526.9238 Houston Tel: 713.781.6100 A.E. W. E. Tel: 800.888.9953 **Rio Grande Valley** A. E. Tel: 210.412.2047 Utah Draper W. Ė. Tel: 800.414.4144 Salt Lake City A. E. Tel: 801.365.3800 W. E. Tel: 800.477.9953 Vermont Tel: 800.272.9255

#### A. E.

Virginia A. Ē. Tel: 800.638.5988

#### Washington

Seattle A. E. Tel: 206.882.7000 W. E. Tel: 800.248.9953

#### West Virginia A. E. Tel: 800.638.5988

#### Wisconsin Milwaukee

A. E. Tel: 414.513.1500 W. E. Tel: 800.867.9953

#### Wyoming

A. E. Tel: 800.332.9326

## Sales Offices and Design Resource Centers

LSI Logic Corporation Corporate Headquarters Tel: 408.433.8000 Fax: 408.433.8989

#### NORTH AMERICA

California Irvine Tel: 949.553.5600

Fax: 949.474.8101 Pleasanton Design Center

Tel: 925.730.8800 Fax: 925.730.8700

San Diego Tel: 619.613.8300 Fax: 619.613.8350

Wireless Design Center Tel: 619.350.5560 Fax: 619.350.0171

Silicon Valley Tel: 408.433.8000 Fax: 408.954.3353

**Colorado** Boulder Tel: 303.447.3800 Fax: 303.541.0641

Florida Boca Raton Tel: 561.989.3236 Fax: 561.989.3237

**Georgia** Roswell Tel: 770.641.8001 Fax: 770.641.8005

Illinois Schaumburg Tel: 847.995.1600 Fax: 847.995.1622

Kentucky Bowling Green Tel: 502.793.0010 Fax: 502.793.0040

Maryland Bethesda Tel: 301.897.5800 Fax: 301.897.8389

Massachusetts Waltham Tel: 781.890.0180 Fax: 781.890.6158

Minnesota Minneapolis ♦ Tel: 612.921.8300 Fax: 612.921.8399

New Jersey Edison ♦ Tel: 732.549.4500 Fax: 732.549.4802 New York Fairport Tel: 716.218.0020 Fax: 716.218.9010

North Carolina Raleigh Tel: 919.785.4520 Fax: 919.783.8909

Oregon Beaverton Tel: 503.645.0589 Fax: 503.645.6612

**Texas** Austin Tel: 512.388.7294 Fax: 512.388.4171

Dallas Tel: 972.503.3205 Fax: 972.503.2258

Tel: 972.244.5000 Fax: 972.244.5001

Houston Tel: 281.379.7800 Fax: 281.379.7818

Washington Issaquah Tel: 425.837.1733 Fax: 425.837.1734

Canada Ontario Ottawa ♦ Tel: 613.592.1263 Fax: 613.592.3253

Toronto Tel: 416.620.7400 Fax: 416.620.5005

Quebec Montreal ♦ Tel: 514.694.2417 Fax: 514.694.2699

#### INTERNATIONAL

Australia New South Wales Reptechnic Pty Ltd Tel: 612.9953.9844 Fax: 612.9953.9683

China Beijing LSI Logic International Services Inc Tel: 86.10.6804.2534 Fax: 86.10.6804.2521

France Paris LSI Logic S.A. Immeuble Europa Tel: 33.1.34.63.13.1

Tel: 33.1.34.63.13.13 Fax: 33.1.34.63.13.19 Germany Munich LSI Logic GmbH Tel: 49.89.4.58.33.0 Fax: 49.89.4.58.33.108

Stuttgart Tel: 49.711.13.96.90 Fax: 49.711.86.61.428

Hong Kong Hong Kong AVT Industrial Ltd Tel: 852.2428.0008 Fax: 852.2401.2105

India Bangalore Spike Technologies India Private Ltd Tel: 91.80.664.5530

Fax: 91.80.664.9748 Israel Ramat Hasharon

LSI Logic Tel: 972.3.5.480480 Fax: 972.3.5.403747

Netanya VLSI Development Centre Tel: 972.9.657190 Fax: 972.9.657194

Italy Milano LSI Logic S.P.A. Tel: 39.039.687371 Fax: 39.039.6057867

Japan Tokyo LSI Logic K.K. Tel: 81.3.5463.7821

Fax: 81.3.5463.7820 Osaka ♦ Tel: 81.6.947.5281 Fax: 81.6.947.5287

Korea Seoul LSI Logic Corporation of Korea Ltd

Tel: 82.2.528.3400 Fax: 82.2.528.2250

The Netherlands Eindhoven LSI Logic Europe Ltd Tel: 31.40.265.3580 Fax: 31.40.296.2109

Singapore Singapore LSI Logic Pte Ltd Tel: 65.334.9061 Fax: 65.334.4749

Tel: 65.835.5040 Fax: 65.732.5047 Sweden Stockholm LSI Logic AB Tel: 46.8.444.15.00 Fax: 46.8.750.66.47

Switzerland Brugg/Biel LSI Logic Sulzer AG Tel: 41.32.536363 Fax: 41.32.536367

Taiwan Taipei LSI Logic Asia-Pacific Tel: 886.2.2718.7828 Fax: 886.2.2718.8869

Avnet-Mercuries Corporation, Ltd Tel: 886.2.2503.1111 Fax: 886.2.2503.1449

Jeilin Technology Corporation, Ltd Tel: 886.2.2248.4828 Fax: 886.2.2242.4397

Lumax International Corporation, Ltd Tel: 886.2.2788.3656 Fax: 886.2.2788.3568

Prospect Technology Corporation, Ltd Tel: 886.2.2721.9533 Fax: 886.2.2773.3756

United Kingdom Bracknell LSI Logic Europe Ltd ♦ Tel: 44.1344.426544 Fax: 44.1344.481039

 Sales Offices with Design Resource Centers